繁体   English   中英

将Json正确转换为XML

[英]Convert Json to XML properly

我有以下字典结构

[{
    "Body" : [{
        "Universal Lift Support" : ["1\"-9\" Extended Length",
                                    "10\"-14.5\" Extended Length",
                                    "15\"-19\" Extended Length",
                                    "20\" + Extended Length"]
    }]

我想使用dicttoxml库来获取所需的xml输出,例如:

<root>
    <Body>
        <Universal Lift Support>
            1"-9" Extended Length
            10"-14.5" Extended Length
            15"-19" Extended Length
            20" + Extended Length
        </Universal Lift Support>

但是,在应用下面的代码后:

dicttoxml.dicttoxml(result, attr_type=False, root=True)

我得到了像这样的xml结构:

<?xml version="1.0" encoding="UTF-8" ?><root><item><Body><item><Universal_Lift_Support><item>1&quot;-9&quot; Extended Length</item><item>10&quot;-14.5&quot; Extended Length</item><item>15&quot;-19&quot; Extended Length</item><item>

哪些选项可以帮助格式化和获取上面描述的输出?

考虑使用遍历json对象并构建XML树的内置Python库( jsonxml.etree.ElementTree和漂亮的xml.dom.minidom )。 需要注意的一件事:XML节点名称中不能包含空格,因此应该<UniversalLiftSupport>

import json
import xml.etree.ElementTree as ET
import xml.dom.minidom

with open('BodyUniversal.json') as f:  
    jsondata = json.load(f)

# INITIALIZING XML DOC AND PARENT TAGS
root = ET.Element('root')
body = ET.SubElement(root, 'Body')
uls = ET.SubElement(body, 'UniversalLiftSupport')
uls.text = ''

# ITERATE THROUGH LIST, APPENDING TO XML
for i in jsondata[0]['Body'][0]['Universal Lift Support']:
    uls.text = uls.text + '\n\t\t\t' + i

# OUTPUT AND PRETTY PRINT TREE
tree_out = ET.tostring(root, encoding="UTF-8")
newXML = xml.dom.minidom.parseString(tree_out.decode('UTF-8'))
pretty_xml = newXML.toprettyxml()    

print(pretty_xml)
# <?xml version="1.0" ?>
# <root>
#         <Body>
#                 <UniversalLiftSupport>
#                         1&quot;-9&quot; Extended Length
#                         10&quot;-14.5&quot; Extended Length
#                         15&quot;-19&quot; Extended Length
#                         20&quot; + Extended Length</UniversalLiftSupport>
#         </Body>
# </root>

# OUTPUT XML CONTENT TO FILE
with open('Output.xml','w') as f:
    f.write(pretty_xml)

可能您将必须编写一个函数以所需的方式为列表生成xml: https : //github.com/quandyfactory/dicttoxml/blob/master/dicttoxml.py

(请参见dicttoxml函数注释)

似乎“ <item>任何</ item>”模式是硬编码的,如果您使用cdata = True,则会得到整个“ <![CDATA [whatever]]>”东西。

如果该软件称为dicttoxml,那么我认为期望它会生成XML是合理的。 您说想要的输出不是XML,因此该工具不会生成它也就不足为奇了。 您似乎在抱怨该产品确实达到了锡上的要求。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM