无法使用jolt解析器将一个json表格转换为另一个。

问题描述 投票:0回答:1

我有一个 data 像下面这样。

{
  "resourceType": "Immunization",
  "id": "example",
  "protocolApplied": [
    {
      "series": "2-dose",
      "authority": {
        "reference": "Organization/org1",
        "type": "Organization",
        "display": "xyz organization"
      },
      "targetDisease": [
        {
          "coding": [
            {
              "system": "http://snomed.info/sct",
              "code": "40468003"
            }
          ]
        }
      ],
      "doseNumberPositiveInt": 1,
      "seriesDosesPositiveInt": 10
    },
    {
      "series": "3-dose",
      "targetDisease": [
        {
          "coding": [
            {
              "system": "http://snomed.info/sct",
              "code": "66071002"
            }
          ]
        }
      ],
      "doseNumberString": "one",
      "seriesDosesString": "ten"
    }
  ]
}  

我需要把它转化成下面的样子 output:

[ {
  "resourceType" : "Immunization",
  "series" : "2-dose",
  "reference" : "Organization/org1",
  "type" : "Organization",
  "display" : "xyz organization",
  "targetDiseaseCodingSystem":"http://snomed.info/sct"
  "targetDiseaseCode":"40468003"
  "doseNumberPositiveInt" : 1,
  "seriesDosesPositiveInt" : 10
}, {
  "resourceType" : "Immunization",
  "series" : "3-dose",
   "targetDiseaseCodingSystem":"http://snomed.info/sct"
  "targetDiseaseCode": "66071002"
  "doseNumberString" : "one",
  "seriesDosesString" : "ten"
} ]  

以下是我的 spec:

[
  {
    "operation": "shift",
    "spec": {
      "protocolApplied": {
        "*": {
          "@(2,resourceType)": "[#2].resourceType",
          "authority": {
            // "reference": "reference"
            "*": "[#3].&"
          },
          "targetDisease": {
            "*": {
              "coding": {
                "*": {
                  //"*": "[#2].&"
                  "@(2,system)": "[#2].targetDiseaseCodingSystem"
                }
              }
            }
          },
          "*": "[#2].&"
        }
      }
    }
    }

]

我在应用以上规格后得到以下输出。

[ {
  "resourceType" : "Immunization",
  "series" : "2-dose",
  "reference" : "Organization/org1",
  "type" : "Organization",
  "display" : "xyz organization",
  "doseNumberPositiveInt" : 1,
  "seriesDosesPositiveInt" : 10
}, {
  "resourceType" : "Immunization",
  "series" : "3-dose",
  "doseNumberString" : "one",
  "seriesDosesString" : "ten"
} ]

其中 targetcodingsystemtargetdiseasecode 是没有填充的。请帮我解决这个问题。

java json xml transformation jolt
1个回答
1
投票

下面是规范将帮助。

使用 [&n],将数值n对象移到上面。

[
  {
    "operation": "shift",
    "spec": {
      "protocolApplied": {
        "*": {
          "@(2,resourceType)": "[&1].resourceType",
          "authority": {
            "*": "[&2].&"
          },
          "targetDisease": {
            "*": {
              "coding": {
                "*": {
                  "system": "[&5].targetDiseaseCodingSystem",
                  "code": "[&5].targetDiseaseCode"
                }
              }
            }
          },
          "*": "[&1].&"
        }
      }
    }
    }
]
© www.soinside.com 2019 - 2024. All rights reserved.