当前位置: 首页 > 知识库问答 >
问题:

震动转换为具有父属性的数组

章增
2023-03-14

我正在使用NiFi Jolt处理器来转换一些JSON数据。

我的JSON字段类型包含共享属性和包含实际类型名称列表的数组。

我需要将“流派”属性转换成一个“流派”数组,包含公共属性和不同流派名称的列表。

我有以下JSON输入:

{
  "programIdentifier": "9184663",
  "programInstance": {
    "genre": {
      "source": "GN",
      "locked": false,
      "lastModifiedDate": 1527505462094,
      "lastModifiedBy": "Some Service",
      "genres": [
        "Miniseries",
        "Drama"
      ]
    }
  }
}

我尝试了以下规格:

[{
  "operation": "shift",
   "spec": {
     "programIdentifier": ".&",,
     "genre": {
        "source": "genres[].source.value",
        "locked": "genres[].locked",
        "lastModifiedDate": "genres[].lastModifiedDate",
        "lastModifiedBy": "genres[].lastModifiedBy",
        "genres": {
            "*": "genres[&0].name"                
        }
     }
}]

这是我的预期输出:

{
  "programIdentifier": "9184663",
  "programInstance": {
    "genres": [
      {
        "source": {
          value: "GN"
        }
        "locked": false,
        "lastModifiedDate": 1527505462094,
        "lastModifiedBy": "Some Service",
        "name": "Miniseries"
      },
      {
        "source": {
          value: "GN"
        }
        "locked": false,
        "lastModifiedDate": 1527505462094,
        "lastModifiedBy": "Some Service",
        "name": "Drama"
      }
    ]
  }
}

但结果是:

{
  "programIdentifier": "9184663",
  "programInstance": {
    "genres": [
      {
    "source": {
      "value": "GN"
    },
    "name": "Miniseries"
       }, {
    "locked": false,
    "name": "Drama"
       }, {
    "lastModifiedDate": 1527505462094
       }, {
    "lastModifiedBy": "Some Service"
       }],
  }
}

共有1个答案

墨安阳
2023-03-14

这是你想要达到的目标吗?

[
  {
    "operation": "shift",
    "spec": {
      "programIdentifier": ".&",
      "programInstance": {
        "genre": {
          "genres": {
            "*": {
              "@2": {
                "source": "programInstance.genres[&2].source[]",
                "locked": "programInstance.genres[&2].locked",
                "lastModifiedDate": "programInstance.genres[&2].lastModifiedDate",
                "lastModifiedBy": "programInstance.genres[&2].lastModifiedBy"
              },
              "@": "programInstance.genres[&1].name"
            }
          }
        }
      }
    }
  }
]
 类似资料:
  • 请,我正在尝试转换从我的Web API返回的此对象: 转换为AngularJS控制器内的这种格式的数组: null [object对象],[object对象]

  • 本文向大家介绍MongoDB查询将数组转换为具有n个属性的文档映射?,包括了MongoDB查询将数组转换为具有n个属性的文档映射?的使用技巧和注意事项,需要的朋友参考一下 为此,您可以使用$map。首先让我们创建一个包含文档的集合- 在方法的帮助下显示集合中的所有文档- 这将产生以下输出- 以下是将数组转换为具有n个属性的文档映射的查询- 这将产生以下输出-

  • 我想知道是否有什么方法可以使属性值动态。类似于这样: 感谢您的反馈。在我的例子中,属性值是系统特定的,应该在测试运行时生成。

  • 我有下一个任务:从某个目录中读取XML文件,并将其转换为JSON字符串。问题是:初始XML和JSON对应属性的名称不同,例如XML中的x_日期和JSON中的j_日期。 我创建了一个类,其中包含JSON的必填字段,并带有这样的注释: 我已经尝试对测试XML文件进行序列化/反序列化,它似乎工作正常。但我不确定同时用JacksonXmlProperty和JsonProperty注释字段是否合适。也许最好

  • 作为一个简化的例子,考虑这个有两个字段的表。一个是字符串,另一个是XML。 Source=“MediaConversions” 现在我想查询该表,并将结果作为json,但也要一次性将XML转换为json。 导致 [{"Source":"媒体转换","OrderParameter":" 但我想把它转换成: [{"Source":"MediaConversion","OrderParameter":{

  • 嗨,我有以下XML 标准是只复制“item-name”属性值为TShert、Ball或Bat的位置。所以生成的XML应该看起来像 我正在使用以下XSLT 但这不起作用。你能帮忙吗? 谢谢Nathan