繁体   English   中英

转换JSON-JSON JOLT

[英]Transform JSON-JSON JOLT

我对JOLT相当陌生,我需要将JSON文件转换为所需的架构。 这是我的意见

[
    {
        "PK": 12345,
        "FULL_NAME":"Amit Prakash",
        "BIRTHDATE":"1987-05-25",
        "SEX":"M",
        "EMAIL": "amprak@mail.com",
        "PHONE": "809386731",
        "TS":"2015-11-19 14:36:34.0"
    },
    {
        "PK": 12654,
        "FULL_NAME": "Rohit Dhand",
        "BIRTHDATE":"1979-02-01",
        "SEX":"M",
        "EMAIL": "rodha@mail.com",
        "PHONE": "937013861",
        "TS":"2015-11-20 11:03:02.6"
    },
    ...
]

这是我想要的输出:

{
    "records": [
        {
            "attribs": [{
                "type": "customer",
                "reference": "CUST"
            }],
            "name": "Amit Prakash",
            "personal_email": "amprak@mail.com",
            "mobile": "809386731",
            "id": 12345 
        },
        {
            "attribs": [{
                "type": "customer",
                "reference": "CUST"
            }],
            "name": "Rohit Dhand",
            "personal_email": "rodha@mail.com",
            "mobile": "937013861",
            "id": 12654 
        },
        ...
    ]
}

到目前为止,我只能做到这一点:

[
  {
    "operation": "remove",
    "spec": {
      "*": {
        "BIRTHDATE": "",
        "SEX": "",
        "TS": ""
      }
    }
  },
  {
    "operation": "shift",
    "spec": {
      "*": "records"
    }
  }
]

但是我不能从这里继续。 我不知道如何重命名输出中的键。

另外, 删除操作的替代方法是什么? 如果要排除的键少于要包含的键,那么remove操作会很好,但是反向操作(要包含的键很少,而不是要在JSON对象中排除的键)怎么样?

规格

[
  {
    "operation": "shift",
    "spec": {
      "*": {
        "PK": "records[&1].id",
        "PHONE": "records[&1].mobile",
        "EMAIL": "records[&1].personal_email",
        "FULL_NAME": "records[&1].name"
      }
    }
  },
  {
    "operation": "default",
    "spec": {
      "records[]": {
        "*": {
          "attribs[]": {
            "0": {
              "type": "customer",
              "reference": "CUST"
            }
          }
        }
      }
    }
  }
]

Shift复制数据,而其他操作则不复制。 因此,删除内容的一种方法是不将其复制到轮班说明中。

通常,remove用于消除会“弄乱”转变的事情。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM