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

输入多个对象时,在对象数组中组合多个值的Jolt变换

何灼光
2023-03-14

我有一个JSON输入:

{
  "Name": "travel.0.0",
  "Documents": [
    {
      "Id": 6732210,
      "Name": "Passport",
      "Fields": [
        {
          "Name": "First Name",
          "Type": "text"
        }
      ],
      "Variants": [
        {
          "Name": "diplomatic_passport",
          "TrainingSamples": [
            {
              "Name": "First Name",
              "Value": "VGhlIFBPU1QsIFBVVCBhbmQgUEFUQ0ggcmVxdWVzdHMgY2FuIGhhdmUgdGhlIHJlcXVlc3QgYm9keSAocGF5bG9hZCksIHN1Y2ggYXMgSlNPTiBvciBYTUwgZGF0YS4gSW4gU3dhZ2dlciB0ZXJtcywgdGhlIHJlcXVlc3QgYm9keSBpcyBjYWxsZWQgYSBib2R5IHBhcmFtZXRlci4gVGhlcmUgY2FuIGJlIG9ubHkgb25lIGJvZHkgcGFyYW1ldGVyLCBhbHRob3VnaCB0aGUgb3BlcmF0aW9uIG1heSBoYXZlIG90aGVyIHBhcmFtZXRlcnMgKHBhdGgsIHF1ZXJ5LCBoZWFkZXIpLg==",
              "BoundingBoxes": [
                {
                  "Name": "string",
                  "Dimensions": [
                    {
                      "PageIndex": 0,
                      "Left": 0,
                      "Top": 0,
                      "Right": 0,
                      "Bottom": 0
                    }
                  ]
                }
              ]
            }
          ]
        }
      ]
    }
  ]
}

我的震动规格是:

[
  {
    "operation": "shift",
    "spec": {
      "Name": "ProjectName",
      "Documents": {
        "*": {
          "Name": {
            "@": ["DocumentDefinitions[#].Name", "DocumentDefinitions[#].SectionDefinitions[#].Name"]
          },
          "Variants": {
            "*": {
              "Name": "DocumentDefinitions[#].SectionDefinitions[#].VarientNames[&1]",
              "TrainingSamples": {
                "0": {
                  "Name": "DocumentDefinitions[#].SectionDefinitions[#].ImageSources[#].ImageName.",
                  "Value": "DocumentDefinitions[#].SectionDefinitions[#].ImageSources[#].ImageValue."
                }
              }
            }
          },
          "Fields": {
            "*": {
              "Name": "DocumentDefinitions[#].SectionDefinitions[#].Fields[&1].Name.",
              "Type": "DocumentDefinitions[#].SectionDefinitions[#].Fields[&1].Type."
            }
          }
        }
      }
    }
  }
]

我的输出是:

{
  "ProjectName" : "travel.0.0",
  "DocumentDefinitions" : [ {
    "Name" : "Passport",
    "SectionDefinitions" : [ {
      "Name" : "Passport",
      "VarientNames" : [ "diplomatic_passport" ],
      "ImageSources" : [ {
        "ImageName" : "First Name",
        "ImageValue" : "VGhlIFBPU1QsIFBVVCBhbmQgUEFUQ0ggcmVxdWVzdHMgY2FuIGhhdmUgdGhlIHJlcXVlc3QgYm9keSAocGF5bG9hZCksIHN1Y2ggYXMgSlNPTiBvciBYTUwgZGF0YS4gSW4gU3dhZ2dlciB0ZXJtcywgdGhlIHJlcXVlc3QgYm9keSBpcyBjYWxsZWQgYSBib2R5IHBhcmFtZXRlci4gVGhlcmUgY2FuIGJlIG9ubHkgb25lIGJvZHkgcGFyYW1ldGVyLCBhbHRob3VnaCB0aGUgb3BlcmF0aW9uIG1heSBoYXZlIG90aGVyIHBhcmFtZXRlcnMgKHBhdGgsIHF1ZXJ5LCBoZWFkZXIpLg=="
      } ],
      "Fields" : [ {
        "Name" : "First Name",
        "Type" : "text"
      } ]
    } ]
  } ]
}

这个输出看起来不错,直到我的输入文档数组中只有一个 JSON 对象。然而,当我放另一个对象时,它看起来有点像这样,这是不希望的。它将两个对象的所有值组合在一起,如下所示:

{
  "ProjectName" : "travel.0.0",
  "DocumentDefinitions" : [ {
    "Name" : [ "Passport", "Passport" ],
    "SectionDefinitions" : [ {
      "Name" : [ "Passport", "Passport" ],
      "VarientNames" : [ [ "diplomatic_passport", "diplomatic_passport" ] ],
      "ImageSources" : [ {
        "ImageName" : [ "First Name", "First Name" ],
        "ImageValue" : [ "VGhlIFBPU1QsIFBVVCBhbmQgUEFUQ0ggcmVxdWVzdHMgY2FuIGhhdmUgdGhlIHJlcXVlc3QgYm9keSAocGF5bG9hZCksIHN1Y2ggYXMgSlNPTiBvciBYTUwgZGF0YS4gSW4gU3dhZ2dlciB0ZXJtcywgdGhlIHJlcXVlc3QgYm9keSBpcyBjYWxsZWQgYSBib2R5IHBhcmFtZXRlci4gVGhlcmUgY2FuIGJlIG9ubHkgb25lIGJvZHkgcGFyYW1ldGVyLCBhbHRob3VnaCB0aGUgb3BlcmF0aW9uIG1heSBoYXZlIG90aGVyIHBhcmFtZXRlcnMgKHBhdGgsIHF1ZXJ5LCBoZWFkZXIpLg==", "VGhlIFBPU1QsIFBVVCBhbmQgUEFUQ0ggcmVxdWVzdHMgY2FuIGhhdmUgdGhlIHJlcXVlc3QgYm9keSAocGF5bG9hZCksIHN1Y2ggYXMgSlNPTiBvciBYTUwgZGF0YS4gSW4gU3dhZ2dlciB0ZXJtcywgdGhlIHJlcXVlc3QgYm9keSBpcyBjYWxsZWQgYSBib2R5IHBhcmFtZXRlci4gVGhlcmUgY2FuIGJlIG9ubHkgb25lIGJvZHkgcGFyYW1ldGVyLCBhbHRob3VnaCB0aGUgb3BlcmF0aW9uIG1heSBoYXZlIG90aGVyIHBhcmFtZXRlcnMgKHBhdGgsIHF1ZXJ5LCBoZWFkZXIpLg==" ]
      } ],
      "Fields" : [ {
        "Name" : [ "First Name", "First Name" ],
        "Type" : [ "text", "text" ]
      } ]
    } ]
  } ]
}

请建议我在JOLT规范中应该做哪些更改,以使数组中的每个变换对象都列为一个单独的对象,而不是被混入。

共有1个答案

寇夜洛
2023-03-14

检查此规格,

[
  {
    "operation": "shift",
    "spec": {
      "Name": "ProjectName",
      "Documents": {
        "*": {
          "Name": "DocumentDefinitions[&1].Name",
          "Variants": {
            "*": {
              "Name": "DocumentDefinitions[&3].SectionDefinitions[&1].VarientNames[]",
              "TrainingSamples": {
                "*": {
                  "Name": "DocumentDefinitions[&5].SectionDefinitions[&1].ImageSources[&1].ImageName",
                  "Value": "DocumentDefinitions[&5].SectionDefinitions[&1].ImageSources[&1].ImageValue"
                }
              }
            }
          },
          "Fields": {
            "*": {
              "Name": "DocumentDefinitions[&3].SectionDefinitions[&3].Fields[&1].Name",
              "Type": "DocumentDefinitions[&3].SectionDefinitions[&3].Fields[&1].Type"
            }
          }
        }
      }
    }
  }
]
 类似资料:
  • 我有一个类似这样的数组: 我想要一个如下所示的结果对象: 我如何在Javascript中实现这一点?

  • 我希望在每个数组中获取多个对象,但我的代码显示了单个对象的操作。下面是我的PHP代码,我如何添加另一个循环来获取多个对象 这是显示单个物体的结果

  • 问题内容: var arrObj = [{a:1, b:2},{c:3, d:4},{e:5, f:6}]; 如何将其合并为一个obj? 问题答案: 如果您的环境支持,那么您可以像这样简洁地进行操作 ES5解决方案: 您可以使用这样的 此解决方案仅将的所有键及其值收集在中的每个对象中,最终将结果返回给我们。 这张支票 有必要确保我们在结果中不包括所有继承的可枚举属性。

  • 我有下面的数组在数组1看到完整,我需要每个子数组合并其中的对象,这样它就像这样。 数组FINAL 因此最终结果是一个包含6个对象的数组。上面的...代表其余的对象。 我试过,但它并不完全符合我的要求。我将在数组2的数组下面发布它的操作 阵列1 这是我不想要的输出,但到目前为止我所能做的一切。在ARRAY FINAL的顶部看到我想要的输出 阵列2 感谢您提前提供的帮助

  • 请帮忙。 谢谢,哈里

  • 我试图通过SQL语句将多行数组和结构插入到Snowflake中。要在列中插入值数组,我使用函数,要插入结构/字典/对象,我使用函数。 这将导致异常: SQL编译错误:VALUES子句中的表达式[Array_Construct(0,1,2)]无效 使用以下语法插入一行可以工作: