0

我遇到了关于用另一个字段的值替换不存在的字段的问题。它解释了modify-default-beta操作的用法。帖子中提到的示例:

规格

[
  {
    "operation": "modify-default-beta",
    "spec": {
      "shipping_address": {
        "address": "@(2,payment_address.address)"
      }
    }
  }
]

输入A,没有收货地址

{
  "payment_address": {
    "address": "some address"
  },
  "shipping_address": {}
}

生成输出 A,其中复制了帐单地址

{
  "payment_address" : {
    "address" : "some address"
  },
  "shipping_address" : {
    "address" : "some address"
  }
}

中的“2”是什么意思@(2,payment_address.address)我在这里尝试了这个示例,即使我将“2”替换为“3”,它仍然有效。

4

1 回答 1

1

Jolt 操作对输入 JSON 和 Spec 进行并行树遍历。它从 Spec & 输入 JSON 的根开始,然后进行深度优先遍历。

虽然它正在执行深度优先遍历,但它会维护它匹配的数据/节点的“堆栈”。

因此,在本规范中,当您“匹配”到“地址”时

"operation": "modify-default-beta",
"spec": {
  "shipping_address": {
    "address": "@(2,payment_address.address)"
  }
}

堆栈看起来像:

Stack "pointer"  Matched value       Pointer to Input
0                "address"           Value of Address : String if it exists
1                "shipping_address"  Value of "shipping_address" : Map if it exists
2                "_root_"            A made up entry to point to Input Json (Map or List)
3                "_root_"            Another "root" that points to a Map  
                                       WorkAround to deal with top level List JSON input

所以“2”让你回到输入Json的“顶层”,这样你就可以“导航”到“payment_address.address”。

“3”之所以有效,是因为您现在处于包装器中,因此所有“顶级”输入到变换都是一个映射,以解决顶级列表/“[]”(如果有效 JSON)的事实。这个包装器是特殊的,具有与“2”相同的引用。

堆栈中不存在“4”,因此它不执行任何操作。

于 2017-11-03T14:06:54.793 回答