Проблема при передаче вывода Json с помощью JOLT - PullRequest
0 голосов
/ 28 сентября 2018

У меня возникла следующая проблема: я получил JSON-ввод, например

{
 "Vorname":"Vorname1 Vorname2",
 "Name":"Nachname
}

, вывод должен быть:

{ "such":"NachnameVorname1Vorname2" }

Моя спецификация JOLT:

 [{
    "operation": "modify-default-beta",
    "spec": {
        "FullName": "=concat(@(1,Vorname),' ' ,@(1,Name))",
        "RFullName": "=concat(@(1,Name),@(1,Vorname))"
    }
}, {
    "operation": "shift",
    "spec": {
        "PersNr": "ymitarb",
        "Austrittsdatum": "ymaust",
        "RFullName": "such",
        "FullName": "name"

    }
}, {
    "operation": "default",
    "spec": {
        "name": "${fname}",
        "such":"$(rfname)",
        "ymitarb": "${nummer}"
    }
}]

и я получаю вывод:

{
    "such": "NachnameVorname1 Vorname2",
    "name": "Vorname1 Vorname2 Nachname",
    "ymitarb": ""
}

в то время как должно быть {"such": "NachnameVorname1Vorname2"}

Моя вторая идея состояла в том, чтобы разделить Vorname на Vorname_x

[{
    "operation": "modify-default-beta",
    "spec": {
        "FullName": "=concat(@(1,Vorname),' ' ,@(1,Name))",
        "RFullName": "=concat(@(1,Name),@(1,Vorname))"
    }
}, {
    "operation": "shift",
    "spec": {
         "Vorname": {
        "* * *": {
          "$(0,1)": "Vorname_1",
          "$(0,2)": "Vorname_2",
          "$(0,3)": "Vorname_3"
        },
           "* *": {"$(0,1)": "Vorname_1",
          "$(0,2)": "Vorname_2"}


      },
        "PersNr": "ymitarb",
        "Austrittsdatum": "ymaust",
        "RFullName": "such",
        "FullName": "name"

    }
}, {
    "operation": "default",
    "spec": {
        "name": "${fname}",
        "such":"$(rfname)",
        "ymitarb": "${nummer}"
    }
}]

здесь вывод:

{
    "Vorname_1": "Vorname1",
    "Vorname_2": "Vorname2",
    "such": "NachnameVorname1 Vorname2",
    "name": "Vorname1 Vorname2 Nachname",
    "ymitarb": ""
}

Мне не удается использовать значения Vorname_1 и Vorname_2 в concat ....., поскольку я не смог найти ни одногорешение

Ответы [ 2 ]

0 голосов
/ 01 октября 2018

Это мой Spec:

 [{
        "operation": "modify-default-beta",
        "spec": {
            "FullName": "=concat(@(1,Vorname_1),' ',@(1,Vorname_2),' ',@(1,Vorname_3),' ',@(1,Name))",
            "RFullName": "=concat(@(1,Name),@(1,Vorname_1),@(1,Vorname_2),@(1,Vorname_3))"
        }
    }, {
        "operation": "shift",
        "spec": {
            "Vorname": {
                "* * *": {
                    "$(0,1)": "Vorname_1",
                    "$(0,2)": "Vorname_2",
                    "$(0,3)": "Vorname_3"
                },
                "* *": {
                    "$(0,1)": "Vorname_1",
                    "$(0,2)": "Vorname_2"
                }


            },
            "Vorname": "Vorname",
            "PersNr": "ymitarb",
            "Name": "Name",
            "Austrittsdatum": "ymaust",
            "RFullName": "such",
            "FullName": "name"

        }
    }, {
        "operation": "default",
        "spec": {
            "name": "${fname}",
            "such": "${rfname}",
            "ymitarb": "${nummer}"
        }
    }]

Ввод:

{
    "Vorname": "Hans Jürgen",
    "Name": "Franz"
}

И вывод, который я получаю:

{
    "Vorname": "Hans Jürgen",
    "Name": "Franz",
    "such": "Franz",
    "name": "  Franz",
    "ymitarb": ""
}

В то время как выход должен быть:

{
    "Vorname_1": "Hans"           //somehow vorname_1 and vorname_2 dosnt work if i  
    "Vorname_2": " Jürgen"       // change your spec
    "Vorname": "Hans Jürgen",
    "Name": "Franz",
    "such": "FranzJürgenHans",
    "name": "Hans Jürgen Franz",
    "ymitarb": ""
}

Что я делаю не так?Также, если «vorname» получил 1 пробел или 2 пробела, то как он должен работать, но как должна выглядеть спецификация, если он также не должен принимать пробелы?

"*": {
"$(0,1)": "Vorname_1"
}

не работает

0 голосов
/ 29 сентября 2018

Спец

[
  {
    "operation": "shift",
    "spec": {
      // split Vorname by a space
      "Vorname": {
        "* *": {
          "$(0,1)": "vorFront",
          "$(0,2)": "vorBack"
        }
      },
      // pass Name thru
      "Name": "Name"
    }
  },
  {
    "operation": "modify-default-beta",
    "spec": {
      // concat the names now that the space is gone
      "such": "=concat(@(1,Name),@(1,vorFront),@(1,vorBack))"
    }
  }
]
...