我正在尝试将多个xml文件合并为一个。我遇到过多个以前回答类似的解决方案。但是,我还没有找到适合我的问题。我有3个不同属性的xml文件。其中一个xml文件有<main1></main>
。我试图获取其他xml文件的内容,并将其与现有数据一起放在此标记中。
test1.xml
<acura>
<Brand>Acura</Brand>
<Model>NSX 2017</Model>
<Price>156000</Price>
</acura>
file2.xml
<honda>
<Brand>Honda</Brand>
<Model>Accord</Model>
<Price>24</Price>
</honda>
something3.xml
<main>
<bmw>
<Brand>BMW</Brand>
<Model>5 Series</Model>
<Price>51200</Price>
</bwm>
</main>
答案 0 :(得分:1)
您可能需要了解的主要内容是insert
。
解析每个文件,然后使用Brand
导航到汽车的品牌作为父母或祖父母。最后insert
。
>>> import os
>>> os.chdir('c:/scratch')
>>> from lxml import etree
>>> test1 = etree.parse('test1.xml')
>>> file2 = etree.parse('file2.xml')
>>> something3 = etree.parse('something3.xml')
>>> acura = test1.find('Brand').getparent()
>>> acura
<Element acura at 0xa27388>
>>> honda = file2.find('Brand').getparent()
>>> main = something3.xpath('.//Brand')[0].getparent().getparent()
>>> main.insert(0, acura)
>>> main.insert(0, honda)
>>> str = etree.tostring(main, pretty_print=True)
>>> str
b'<main>\n<honda>\n <Brand>Honda</Brand>\n <Model>Accord</Model>\n <Price>24</Price>\n</honda><acura>\n <Brand>Acura</Brand>\n <Model>NSX 2017</Model>\n <Price>156000</Price>\n</acura><bmw>\n <Brand>BMW</Brand>\n <Model>5 Series</Model>\n <Price>51200</Price>\n</bmw>\n</main>\n'