3

Java を使用して JSON 本体を取り込み、レコードを繰り返し処理し、他のすべてのレコードを新しい JSON 配列に出力したいと考えています。2 つのレコードの各セットは独自の配列になるため、それぞれの配列の最初のレコードのみを取得する必要があります。また、後続のフラット化されたオブジェクトに追加する必要がある元のリクエストの列名も提供します。たとえば、次の JSON 要求本文があるとします。

{
  "records": [
    [
        [
            "0DFC29E2-700E-4CC1-931E-B61DF4954B6B",
            "John Doe",
            "Teacher",
            "China"
        ],
        [
            "B5B9186E-CE65-4911-8516-C510D3CC3ACE",
            "Jane Doe",
            "Doctor",
            "London"
        ]
    ],
    [
        [
            "20C4DD07-4E96-47F8-A1E1-B20B4C48120C",
            "Jim Doe",
            "Lawyer",
            "Canada"
        ],
        [
            "76718CB1-238F-418E-BD14-5E2867FF3FB4",
            "Jack Doe",
            "Chef",
            "Mexico"
        ]
     ]
   ],
    "columns": [
     "ID",
     "Name",
     "Occupation",
     "Location"
   ]
}

次に、このリクエスト本文を次のようにフラット化します。

[{
  "ID": "0DFC29E2-700E-4CC1-931E-B61DF4954B6B",
  "Name": "John Doe",
  "Occupation": "Teacher",
  "Location": "China"
},
{
  "ID": "20C4DD07-4E96-47F8-A1E1-B20B4C48120C",
  "Name": "Jim Doe",
  "Occupation": "Lawyer",
  "Location": "Canada"
}]

このコードをかなり動的にしたいので、コード内で列名を明示的に参照しません。そうすれば、別の JSON 本体構造を持っている場合に、将来他の列名を渡すことができ、それに応じて機能します。私は常に「レコード」というタイトルのデータを渡すので、ハードコーディングしても問題ありません。どんな助けでも大歓迎です。

4

2 に答える 2

0

ソース JSON を一連の Java オブジェクトに読み込み、Java 側で変換を行い、新しい形式で出力できます。

XSLT に相当する JSON があればいいのですが、一般的に使用されているものは見たことがありません。

于 2013-05-09T22:29:34.750 に答える
0

ソース JSON をマップのコレクションに変換する必要があります。各マップには、プロパティ名とプロパティ値が含まれます。その後、期待される形式に簡単にシリアル化できます。以下の例ではJacksonライブラリを使用していますが、 Gsonライブラリも使用できるはずです。

最初に、SourceEntity入力 JSON のすべてのプロパティを定義するクラスを定義する必要があります。

class SourceEntity {

    private String[][][] records;
    private String[] columns;

    public String[][][] getRecords() {
        return records;
    }

    public void setRecords(String[][][] records) {
        this.records = records;
    }

    public String[] getColumns() {
        return columns;
    }

    public void setColumns(String[] columns) {
        this.columns = columns;
    }
}

その後、入力 JSON を解析し、配列をマップのコレクションに変換し、それをターゲット JSON にシリアル化できるコンバーターを作成する必要があります。

class JsonConverter {

    private ObjectMapper objectMapper = new ObjectMapper();
    private JsonFactory jsonFactory = new JsonFactory();

    public String convert(File sourceJsonFile) throws Exception {
        SourceEntity sourceEntity = parseSourceEntity(sourceJsonFile);
        List<Map<String, String>> result = convertToTargetPropertiesMap(sourceEntity);

        return objectMapper.writeValueAsString(result);
    }

    private SourceEntity parseSourceEntity(File sourceJsonFile)
            throws Exception {
        JsonParser parser = jsonFactory.createJsonParser(sourceJsonFile);
        return objectMapper.readValue(parser, SourceEntity.class);
    }

    private List<Map<String, String>> convertToTargetPropertiesMap(
            SourceEntity entity) {
        List<Map<String, String>> list = new ArrayList<Map<String, String>>();
        for (String[][] pairs : entity.getRecords()) {
            list.add(createPropertyMap(entity.getColumns(), pairs[0]));
        }
        return list;
    }

    private Map<String, String> createPropertyMap(String[] names,
            String[] values) {
        Map<String, String> propertyMap = new LinkedHashMap<String, String>();
        for (int i = 0; i < values.length; i++) {
            propertyMap.put(names[i], values[i]);
        }
        return propertyMap;
    }
}

最後に、ちょっとしたテストを書きましょう:

import java.io.File;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.databind.ObjectMapper;

public class JacksonProgram {

    public static void main(String[] args) throws Exception {
        JsonConverter converter = new JsonConverter();
        String result = converter.convert(new File("/tmp/source.json"));
        System.out.println(result);
    }
}

上記のプログラムは、入力例として次の JSON を出力します。

[{"ID":"0DFC29E2-700E-4CC1-931E-B61DF4954B6B","Name":"John Doe","Occupation":"Teacher","Location":"China"},{"ID":"20C4DD07-4E96-47F8-A1E1-B20B4C48120C","Name":"Jim Doe","Occupation":"Lawyer","Location":"Canada"}]
于 2013-05-09T22:55:05.613 に答える