将 JSON 个键解析为字段值
Parsing JSON keys as field value
我有一个翻译 JSON 对象,它将语言环境映射到消息并采用以下形式:
{"en_US" : "English Text", "sp": "Spanish Text", "fr" : "French Text", ... }
我可以使用 gson 将 JSON 对象映射为以下 class 的列表吗?
class Translation {
String locale, text;
}
我知道我可以先将其解析为地图,然后遍历地图元素以创建 Translation 对象,但我不确定是否有 "gson" 方法可以做到这一点。
有两种选择。如果您需要序列化和反序列化数据,您可以编写自定义 TypeAdapter
.
class TranslationTypeAdapter extends TypeAdapter<List<Translation>> {
@Override
public void write(JsonWriter out, List<Translation> list) throws IOException {
out.beginObject();
for(Translation t : list) {
out.name(t.locale).value(t.text);
}
out.endObject();
}
@Override
public List<Translation> read(JsonReader in) throws IOException {
List<Translation> list = new ArrayList<>();
in.beginObject();
while(in.hasNext()) {
list.add(new Translation(in.nextName(), in.nextString()));
}
in.endObject();
return list;
}
}
然后:
TypeToken typeToken = new TypeToken<List<Translation>>(){};
Type type = typeToken.getType();
Gson gson = new GsonBuilder().registerTypeAdapter(type, new TranslationTypeAdapter()).create();
List<Translation> list = gson.fromJson(new FileReader(new File("json")),type);
输出:
[Translation{locale='en_US', text='English Text'}, Translation{locale='sp', text='Spanish Text'}, Translation{locale='fr', text='French Text'}]
但是,如果您只需要反序列化数据,您可以编写自定义反序列化程序:
class TranslationDeserializer implements JsonDeserializer<List<Translation>> {
@Override
public List<Translation> deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
List<Translation> list = new ArrayList<>();
for(Map.Entry<String, JsonElement> entry : json.getAsJsonObject().entrySet()) {
list.add(new Translation(entry.getKey(), entry.getValue().getAsString()));
}
return list;
}
}
与第一个示例中一样,使用 GsonBuilder
注册此反序列化器。这当然会产生相同的输出。
我有一个翻译 JSON 对象,它将语言环境映射到消息并采用以下形式:
{"en_US" : "English Text", "sp": "Spanish Text", "fr" : "French Text", ... }
我可以使用 gson 将 JSON 对象映射为以下 class 的列表吗?
class Translation {
String locale, text;
}
我知道我可以先将其解析为地图,然后遍历地图元素以创建 Translation 对象,但我不确定是否有 "gson" 方法可以做到这一点。
有两种选择。如果您需要序列化和反序列化数据,您可以编写自定义 TypeAdapter
.
class TranslationTypeAdapter extends TypeAdapter<List<Translation>> {
@Override
public void write(JsonWriter out, List<Translation> list) throws IOException {
out.beginObject();
for(Translation t : list) {
out.name(t.locale).value(t.text);
}
out.endObject();
}
@Override
public List<Translation> read(JsonReader in) throws IOException {
List<Translation> list = new ArrayList<>();
in.beginObject();
while(in.hasNext()) {
list.add(new Translation(in.nextName(), in.nextString()));
}
in.endObject();
return list;
}
}
然后:
TypeToken typeToken = new TypeToken<List<Translation>>(){};
Type type = typeToken.getType();
Gson gson = new GsonBuilder().registerTypeAdapter(type, new TranslationTypeAdapter()).create();
List<Translation> list = gson.fromJson(new FileReader(new File("json")),type);
输出:
[Translation{locale='en_US', text='English Text'}, Translation{locale='sp', text='Spanish Text'}, Translation{locale='fr', text='French Text'}]
但是,如果您只需要反序列化数据,您可以编写自定义反序列化程序:
class TranslationDeserializer implements JsonDeserializer<List<Translation>> {
@Override
public List<Translation> deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
List<Translation> list = new ArrayList<>();
for(Map.Entry<String, JsonElement> entry : json.getAsJsonObject().entrySet()) {
list.add(new Translation(entry.getKey(), entry.getValue().getAsString()));
}
return list;
}
}
与第一个示例中一样,使用 GsonBuilder
注册此反序列化器。这当然会产生相同的输出。