ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python-混淆使用哪个XML处理选项

2019-11-02 13:56:28  阅读:224  来源: 互联网

标签:minidom dom elementtree xml python


我对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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有