时间:2021-05-22
问题
你想读取一个XML文档,对它最一些修改,然后将结果写回XML文档。
解决方案
使用 xml.etree.ElementTree 模块可以很容易的处理这些任务。 第一步是以通常的方式来解析这个文档。例如,假设你有一个名为 pred.xml 的文档,类似下面这样:
下面是一个利用 ElementTree 来读取这个文档并对它做一些修改的例子:
>>> from xml.etree.ElementTree import parse, Element>>> doc = parse('pred.xml')>>> root = doc.getroot()>>> root<Element 'stop' at 0x100770cb0>>>> # Remove a few elements>>> root.remove(root.find('sri'))>>> root.remove(root.find('cr'))>>> # Insert a new element after <nm>...</nm>>>> root.getchildren().index(root.find('nm'))1>>> e = Element('spam')>>> e.text = 'This is a test'>>> root.insert(2, e)>>> # Write back to a file>>> doc.write('newpred.xml', xml_declaration=True)>>>处理结果是一个像下面这样新的XML文件:
讨论
修改一个XML文档结构是很容易的,但是你必须牢记的是所有的修改都是针对父节点元素, 将它作为一个列表来处理。例如,如果你删除某个元素,通过调用父节点的 remove() 方法从它的直接父节点中删除。 如果你插入或增加新的元素,你同样使用父节点元素的 insert() 和 append() 方法。 还能对元素使用索引和切片操作,比如 element[i] 或 element[i:j]
如果你需要创建新的元素,可以使用本节方案中演示的 Element 类。我们在6.5小节已经详细讨论过了。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
有如下的xml文件:复制代码代码如下:12下面介绍python解析xml文件的几种方法,使用python模块实现。方式1,python模块实现自动遍历所有节点:
BeautifulSoup是一个用来从HTML或XML文件中提取数据的Python库,它利用大家所喜欢的解析器提供了许多惯用方法用来对文档树进行导航、查找和修改
本文实例讲述了Python使用minidom读写xml的方法。分享给大家供大家参考。具体分析如下:一python提供的xml支持2种工业标准的xml解析方法-S
问题你想解析某个XML文档,文档中使用了XML命名空间。解决方案考虑下面这个使用了命名空间的文档:DavidBeazleyHelloWorldHelloWorl
本文实例讲述了python解析xml文件的方法。分享给大家供大家参考。具体如下:python解析xml非常方便。在diveintopython中也有讲解。如果x