忽略JSON到XML转换中的键

问题描述 投票:2回答:3

我使用json库将json转换为xml但在转换时我想忽略一个嵌套的json对象转换为xml标签。

例如。

飞机json如下:

{"id":"9568","name":"Customer Analysis","group":"demo","param":{"globalSettings":{"showLegends":false,"legendPosition":"bottom center"}}}

JSONObject json = new JSONObject("{\"id\":\"9568\",\"name\":\"Customer Analysis\",\"group\":\"demo\",\"param\":{\"globalSettings\":{\"showLegends\":false,\"legendPosition\":\"bottom center\"}}}");

    String xml = XML.toString(json);
    System.out.println(xml);

现在在上面的例子中,我希望在xml中使用json,因为它在里面。而现在为globalSettings中的showLegends和legendPosition创建了各种元素。

当前的XML如下:

<name>Customer Analysis</name>
<id>9568</id>
<group>demo</group>
<param>
  <globalSettings>
     <showLegends>false</showLegends>
     <legendPosition>bottom center</legendPosition>
  </globalSettings>
</param>

预期的XML应如下:

<name>Customer Analysis</name>
<id>9568</id>
<group>demo</group>
<param>
  <globalSettings>
     {"showLegends":false,"legendPosition":"bottom center"}
  </globalSettings>
</param>

我怎么处理这个?

java json xml xml-parsing
3个回答
2
投票

我认为你需要在转换之前调整JSON。你能在下面试试吗?

String json = "{\n" +
        "   \"user\": \"gerry\",\n" +
        "   \"likes\": [1, 2, 4],\n" +
        "   \"followers\": {\n" +
        "      \"options\": {\n" +
        "        \"key1\": \"a\",\n" +
        "        \"key2\": \"b\"\n" +
        "      }        \n" +
        "   }\n" +
        "}";

JSONObject jsonObject = new JSONObject(json);
JSONObject followers = jsonObject.getJSONObject("followers");

String options = followers.optString("options");
followers.put("options", options);

String s = XML.toString(jsonObject);
System.out.println(XML.unescape(s));

结果:

<followers><options>{"key1":"a","key2":"b"}</options></followers><user>gerry</user><likes>[1,2,4]</likes>

额外问题:

如果我不想将选项作为xml元素并且它应该是json的一部分怎么办?

String json = "{\n" +
        "   \"user\": \"gerry\",\n" +
        "   \"likes\": [1, 2, 4],\n" +
        "   \"followers\": {\n" +
        "      \"options\": {\n" +
        "        \"key1\": \"a\",\n" +
        "        \"key2\": \"b\"\n" +
        "      }        \n" +
        "   }\n" +
        "}";

JSONObject jsonObject = new JSONObject(json);
jsonObject.put("followers", jsonObject.optString("followers"));

// org.json 20180813
String s = XML.toString(jsonObject);
System.out.println(XML.unescape(s));

结果:

<followers>{"options":{"key1":"a","key2":"b"}}</followers><user>gerry</user><likes>1</likes><likes>2</likes><likes>4</likes>

0
投票

您需要稍微修改一下json:

    String json = "{\"user\":\"gerry\",\"likes\":[1,2,4],\"followers\":{\"options\":\"{key1:a,key2:b}\"}}";

    JSONObject jsonObject = new JSONObject(json);
    String xml = XML.toString(jsonObject);

    System.out.println(XML.unescape(xml));

请注意,“options”应为“String”(形状类似于JSON),然后XML解析器会将其视为常规字符串。


0
投票

您需要在转换之前调整JSON,或者在转换后调整XML。

由于经常需要进行这种调整,因此一种方法是使用XSLT 3.0进行转换,因此您可以使用内置于该工具的转换功能。

© www.soinside.com 2019 - 2024. All rights reserved.