0

根据下面的代码片段,我有 XML 文档需要使用 org.json 转换为 JSON。但是这种方法的问题是它不会在原始 XML 中保留 HTML 标签,例如将 XML 文本 <abstract>the max power density was 582.4 mW/m<sup>2</sup>. After temperature decreasing</abstract>映射到

"abstract":"the max power density was 582.4 mW/m. After temperature decreasing". 知道如何保留 HTML 标签吗?

try(FileWriter out = new FileWriter(new File("json.json")))
        {
            JSONObject json = XML.toJSONObject(new StringReader(xmlRec));
            String jsonString = json.toString(4);
            System.out.println("JSON str:  " + jsonString);
            out.write(jsonString);
        }
        catch(FileNotFoundException ex)
        {
            ex.printStackTrace();
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
4

1 回答 1

1

这是神奇的 XML 到 JSON 代码:

// Changes XML to JSON
function xmlToJson(xml) {
    
    // Create the return object
    var obj = {};

    if (xml.nodeType == 1) { // element
        // do attributes
        if (xml.attributes.length > 0) {
        obj["@attributes"] = {};
            for (var j = 0; j < xml.attributes.length; j++) {
                var attribute = xml.attributes.item(j);
                obj["@attributes"][attribute.nodeName] = attribute.nodeValue;
            }
        }
    } else if (xml.nodeType == 3) { // text
        obj = xml.nodeValue;
    }

    // do children
    if (xml.hasChildNodes()) {
        for(var i = 0; i < xml.childNodes.length; i++) {
            var item = xml.childNodes.item(i);
            var nodeName = item.nodeName;
            if (typeof(obj[nodeName]) == "undefined") {
                obj[nodeName] = xmlToJson(item);
            } else {
                if (typeof(obj[nodeName].push) == "undefined") {
                    var old = obj[nodeName];
                    obj[nodeName] = [];
                    obj[nodeName].push(old);
                }
                obj[nodeName].push(xmlToJson(item));
            }
        }
    }
    return obj;
};

我需要实现的主要更改是使用 attributes.item(j) 而不是我发现的大多数脚本使用的 attributes[j]。使用这个函数,XML 看起来像:

<ALEXA VER="0.9" URL="davidwalsh.name/" HOME="0" AID="=">
    <SD TITLE="A" FLAGS="" HOST="davidwalsh.name">
        <TITLE TEXT="David Walsh Blog :: PHP, MySQL, CSS, Javascript, MooTools, and Everything Else"/>
        <LINKSIN NUM="1102"/>
        <SPEED TEXT="1421" PCT="51"/>
    </SD>
    <SD>
        <POPULARITY URL="davidwalsh.name/" TEXT="7131"/>
        <REACH RANK="5952"/>
        <RANK DELTA="-1648"/>
    </SD>
</ALEXA>

...成为具有以下结构的 JavaScript 对象:

{
    "@attributes": {
        AID: "=",
        HOME:  0,
        URL: "davidwalsh.name/",
        VER: "0.9",
    },
    SD = [
        {
            "@attributes": {
                FLAGS: "",
                HOST: "davidwalsh.name",
                TITLE: A
            },
            LINKSIN: {
                "@attributes": {
                    NUM: 1102
                }
            },
            SPEED: {
                "@attributes": {
                    PCT: 51,
                    TEXT: 1421
                }
            },
            TITLE: {
                "@attributes": {
                    TEXT: "David Walsh Blog :: PHP, MySQL, CSS, Javascript, MooTools, and Everything Else",
                }
            },
        },
        {
            POPULARITY: {
                "@attributes": {
                    TEXT: 7131,
                    URL: "davidwalsh.name/"
                }
            },
            RANK: {
                "@attributes": {
                    DELTA: "-1648"
                }
            },
            REACH: {
                "@attributes": {
                    RANK = 5952
                }
            }
        }
    ]
}

从这里您可以使用您认为合适的 JavaScript 对象。如果您想要字符串 JSON 格式的 JavaScript,您可以编写以下代码:

// 假设 xmlDoc 是 XML DOM 文档

var jsonText = JSON.stringify(xmlToJson(xmlDoc));

这个函数非常有用,可以让我快速忽略 XML 并改用 JSON。该函数在构建嵌套子节点的属性和数组时效果很好。随身携带;在某些时候,您可能需要将 XML 转换为 JSON!

于 2021-12-21T22:24:02.890 回答