Как я могу преобразовать с помощью Json с помощью болта? - PullRequest
0 голосов
/ 10 февраля 2019

Мне нужно преобразовать один JSON в другой JSON, я новичок в jolt.Если у вас есть другие методы в java, пожалуйста, дайте мне знать.Входные данные могут иметь много других атрибутов вложенным способом.Я должен сделать общий код, который может использовать все поля в JSON и преобразовать его в желаемый результат, который я упомянул.

Ввод

  {   
        "id": "123456789",
        "OrderType": "ABC",
        "Abc": [
           {
              "Name": "Pluto",
              "Value": "Charon"
           },
           {
              "Name": "Earth",
              "Value": "Moon"
           }
        ]
   }

Требуемый вывод

  "MyFieldList": [
  {
    "Footer": "My Footer",
    "fieldList": [
      {
        "label": "id",
        "fieldName": "id",
        "fieldValue": "123456789",
        "editable": false, 
        "dataType": "STRING"
      },
      {
        "label": "OrderType",
        "fieldName": "OrderType",
        "fieldValue": "ABC",
        "editable": false, 
        "dataType": "STRING"
      },
      {
        "label": "Pluto",
        "fieldName": "Pluto",
        "fieldValue": "Charon",
        "editable": false, 
        "dataType": "STRING"
      },
      {
        "label": "Earth",
        "fieldName": "Earth",
        "fieldValue": "Moon",
        "editable": false, 
        "dataType": "STRING"
      }]
  }
  ]

Я пытался использовать эту спецификацию толчка, но я не могу понять, как вложить эту часть, как ее сгладить.

 {
"operation": "shift",
"spec": {
    "*": {
      "$": "[#2].fieldName",
      "@": "[#2].fieldValue",
      "#false": "[#2].editable",
      "# ": "[#2].Size",
      "#STRING": "[#2].dataType"
    }
  }
 }

1 Ответ

0 голосов
/ 11 февраля 2019

Важной частью является создание массива массивов, прежде чем превратить в fieldList:

[
  {
    "operation": "shift",
    "spec": {
      "id": {
        "$": "[#1].[#1].fieldName",
        "@": "[#1].[#1].fieldValue",
        "#false": "[#1].[#1].editable",
        "#STRING": "[#1].[#1].dataType"
      },
      "OrderType": {
        "$": "[#2].[#1].fieldName",
        "@": "[#2].[#1].fieldValue",
        "#false": "[#2].[#1].editable",
        "#STRING": "[#2].[#1].dataType"
      },
      "Abc": {
        "*": {
          "Name": "[#3].[&1].fieldName",
          "Value": "[#3].[&1].fieldValue",
          "#false": "[#3].[&1].editable",
          "#STRING": "[#3].[&1].dataType"
        }
      }
    }
 },
  {
    "operation": "shift",
    "spec": {
      "*": {
        "*": "MyFieldList.fieldList.[]"
      }
    }
  },
  {
    "operation": "default",
    "spec": {
      "MyFieldList": {
        "Footer": "My Footer"
      }
    }
  }
]

...