python-混淆使用哪个XML处理选项
作者:互联网
我对Python相当陌生,而且我刚开始使用XML解析.我对使用XML的所有选择感到有些不知所措,希望有经验的人可以针对我正在研究的简单问题给我一些建议(也许是代码示例?).
我正在开发一个不涉及数据库的简单Python联系人管理应用程序-每个联系人的信息都使用XML存储在单独的文本文件中.例如,假设以下是文件“ 1234.xml”的内容
<contact>
<id>1234</id>
<name>Johnny Appleseed</name>
<phone>8145551212</phone>
<address>
<street>1234 Main Street</street>
<city>Hometown</city>
<state>OH</state>
</address>
<address>
<street>1313 Mockingbird Lane</street>
<city>White Plains</city>
<state>NY</state>
</address>
</contact>
为了举例说明,我们假设只能有一个电话号码,但是可以有多个地址块.
对于我在这里所做的事情,我需要能够从文件中解析XML,对数据进行更改,然后更新XML并将其保存回文件中.假设可能发生三种类型的数据更改:
>更改一项或多项内容的数据,例如更新电话号码
>添加一个新的地址块(以及新地址的街道/城市/州的相应数据)
>删除现有地址块
鉴于我在这里要做的事情,您能推荐一种特殊的方法吗? (SAX,DOM,minidom,ElementTree,还是其他?)您所建议的代码示例将不胜感激.
谢谢!
罗恩
解决方法:
SAX和DOM API较旧;它们几乎已从Java世界转换为Python. ElementTree API是专门为Pythonic设计的,即适合Python解决问题的方式,因此更喜欢这种方式.
我知道,最丰富,最快的ElementTree实现是lxml.它的XPath功能非常有用.未经测试的示例:
from lxml import etree
contacts = etree.parse(open("1234.xml"))
for c in contacts.xpath('//contact'):
if c.xpath('/name')[0].text == 'Johnny Appleseed':
c.xpath('/phone')[0].text = NEW_PHONE_NUMBER
print >> open("1234.xml", "w"), etree.tostring(contacts)
标签:minidom,dom,elementtree,xml,python 来源: https://codeday.me/bug/20191102/1991821.html