摘要:我们经常需要解析用不同语言编写的数据。Python提供了许多库来解析或拆分用其他语言编写的数据。在此 Python XML 解析器教程中,您将学习如何使用 Python 解析 XML。

本文分享自华为云社区《从零开始学python | 如何在 Python 中解析和修改 XML?》,原文作者:Yuchuan。

我们经常需要解析用不同语言编写的数据。Python提供了许多库来解析或拆分用其他语言编写的数据。在此 Python XML 解析器教程中,您将学习如何使用 Python 解析 XML。

以下是本教程中涵盖的所有主题:

What is XML?
Python XML Parsing Modules
xml.etree.ElementTree Module

  • Using parse() function
  • Using fromstring() function
  • Finding Elements of Interest
  • Modifying XML files
  • Adding to XML
  • Deleting from XML

xml.dom.minidom Module

  • Using parse() function
  • Using fromString() function
  • Finding Elements of Interest

让我们开始吧。:)

什么是 XML

XML 代表可扩展标记语言。它在外观上类似于HTML,但 XML 用于数据表示,而 HTML 用于定义正在使用的数据。XML 专门设计用于在客户端和服务器之间来回发送和接收数据。看看下面的例子:

例子:

<? xml version ="1.0" encoding ="UTF-8" ?><metadata><food><item name ="breakfast" > Idly </item><price> $2.5 </price><description>两个 idly's with chutney< /description><calories> 553 </calories></food><food><item name ="breakfast" > Paper Dosa </item><price> $2.7 </price><<calories> 700 </calories></food><food><item name ="breakfast" > Upma </item><price> $3.65 </price><description>Rava upma with bajji</description><calories> 600 </calories></food><food><item name ="breakfast" > Bisi Bele Bath </item><price> $4.50 </price><description>Bisi Bele Bath with sev</description><calories> 400 </calories>
</food><food><item name ="breakfast" > Kesari Bath </item><price> $1.95 </price><description>藏红花甜拉瓦</description><calories> 950 </calories></食物></元数据>

上面的示例显示了我命名为“Sample.xml”的文件的内容,我将在此 Python XML 解析器教程中为所有即将推出的示例使用相同的内容。

Python XML 解析模块

Python允许使用两个模块解析这些 XML 文档,即 xml.etree.ElementTree 模块和 Minidom(最小 DOM 实现)。解析意味着从文件中读取信息并通过识别该特定 XML 文件的部分将其拆分为多个部分。让我们进一步了解如何使用这些模块来解析 XML 数据。

xml.etree.ElementTree 模块:

该模块帮助我们在树结构中格式化 XML 数据,这是分层数据的最自然表示。元素类型允许在内存中存储分层数据结构,并具有以下属性:

ElementTree 是一个包装元素结构并允许与 XML 相互转换的类。现在让我们尝试使用python 模块解析上述 XML 文件。

有两种使用“ElementTree”模块解析文件的方法。第一个是使用parse() 函数,第二个是fromstring() 函数。parse() 函数解析作为文件提供的 XML 文档,而 fromstring 解析作为字符串提供的 XML,即在三引号内。

使用 parse() 函数:

如前所述,该函数采用文件格式的 XML 来解析它。看下面的例子:

例子:

import xml.etree.ElementTree as ET
mytree = ET.parse('sample.xml')
myroot = mytree.getroot()

如您所见,您需要做的第一件事是导入 xml.etree.ElementTree 模块。然后, parse() 方法解析“Sample.xml”文件。getroot() 方法返回“Sample.xml”的根元素。

执行上述代码时,您不会看到返回的输出,但不会出现表明代码已成功执行的错误。要检查根元素,您可以简单地使用 print 语句,如下所示:

例子:

import xml.etree.ElementTree as ET
mytree = ET.parse('sample.xml')
myroot = mytree.getroot()
print(myroot)

输出:    <元素'元数据'在0x033589F0>

上面的输出表明我们的 XML 文档中的根元素是“元数据”。

使用 fromstring() 函数:

您还可以使用 fromstring() 函数来解析您的字符串数据。如果要执行此操作,请将XML作为字符串传递给三引号,如下所示:

import xml.etree.ElementTree as ET
data='''<?xml version="1.0" encoding="UTF-8"?>
<metadata>
<food><item name="breakfast">Idly</item><price>$2.5</price><description>Two idly's with chutney</description><calories>553</calories>
</food>
</metadata>
'''
myroot = ET.fromstring(data)
#print(myroot)
print(myroot.tag)

上面的代码将返回与前一个相同的输出。请注意,用作字符串的 XML 文档只是“Sample.xml”的一部分,我使用它来提高可见性。您也可以使用完整的 XML 文档。

您还可以使用“标签”对象检索根标签,如下所示:

例子:

print(myroot.tag)

输出:  元数据

您还可以通过指定要在输出中看到的字符串部分来对标签字符串输出进行切片。

例子:

print(myroot.tag[0:4])

输出:  

如前所述,标签也可以具有字典属性。要检查根标记是否具有任何属性,您可以使用“attrib”对象,如下所示:

例子:

print(myroot.attrib)

输出: {}

如您所见,输出是一个空字典,因为我们的根标签没有属性。

寻找感兴趣的元素:

根也由子标签组成。要检索根标记的子项,您可以使用以下命令:

例子:

print(myroot[0].tag)

输出:食物

现在,如果要检索根的所有第一个子标签,可以使用 for 循环迭代它,如下所示:

例子:

for x in myroot[0]:print(x.tag, x.attrib)

输出:

item {'name': 'breakfast'}
价格 {}
描述 {}
卡路里 {}

返回的所有项目都是食物的子属性和标签。

要使用 ElementTree 将文本从 XML 中分离出来,您可以使用 text 属性。例如,如果我想检索有关第一个食品的所有信息,我应该使用以下代码:

例子:

for x in myroot[0]:print(x.text)

输出:

懒懒地
$ 2.5
两悠闲地与酸辣酱的
553

可以看到,第一项的文本信息已经作为输出返回了。现在,如果您想显示具有特定价格的所有商品,您可以使用 get() 方法。此方法访问元素的属性。

例子:

for x in myroot.findall('food'):item =x.find('item').textprice = x.find('price').textprint(item, price)

输出:

Idly $2.5
Paper Dosa $2.7
Upma $3.65
Bisi Bele Bath $4.50
Kesari Bath $1.95

上面的输出显示了所有必需的项目以及每个项目的价格。使用 ElementTree,您还可以修改 XML 文件。

修改 XML 文件:

可以操作 XML 文件中的元素。为此,您可以使用 set() 函数。让我们首先看看如何向 XML 添加一些东西。

添加到 XML

以下示例显示了如何在项目描述中添加内容。

例子:

for description in myroot.iter('description'):new_desc = str(description.text)+'wil be served'description.text = str(new_desc)description.set('updated', 'yes')mytree.write('new.xml')

write() 函数帮助创建一个新的 xml 文件并将更新的输出写入相同的文件。但是,您也可以使用相同的功能修改原始文件。执行完上述代码后,您将能够看到已创建具有更新结果的新文件。

上图显示了对我们食品的修改描述。要添加新的子标签,您可以使用 SubElement() 方法。例如,如果您想在第一项 Idly 中添加一个新的专业标签,您可以执行以下操作:

例子:

ET.SubElement(myroot[0], 'speciality')
for x in myroot.iter('speciality'):new_desc = 'South Indian Special'x.text = str(new_desc)mytree.write('output5.xml')

输出:

如您所见,在第一个食品标签下添加了一个新标签。通过在 [] 括号内指定下标,您可以在任何地方添加标签。现在让我们看一下如何使用此模块删除项目。

 XML 中删除:

要使用 ElementTree 删除属性或子元素,您可以使用 pop() 方法。此方法将删除用户不需要的所需属性或元素。

例子:

myroot[0][0].attrib.pop('name', None)# create a new XML file with the results
mytree.write('output5.xml')

输出:

上图显示name属性已从item标记中删除。要删除完整的标签,您可以使用相同的 pop() 方法,如下所示:

例子:

myroot[0].remove(myroot[0][0])
mytree.write('output6.xml')

输出:

输出显示食品标签的第一个子元素已被删除。如果要删除所有标签,可以使用 clear() 函数,如下所示:

例子:

myroot[0].clear()
mytree.write('output7.xml')

输出:

执行上述代码时,food 标签的第一个子标签将被完全删除,包括所有子标签。到这里为止,我们一直在使用这个 Python XML 解析器教程中的 xml.etree.ElementTree 模块。现在让我们看看如何使用 Minidom 解析 XML。

xml.dom.minidom模块:

这个模块基本上是由精通DOM(文档对象模块)的人使用的。DOM 应用程序通常首先将 XML 解析为 DOM。在 xml.dom.minidom 中,这可以通过以下方式实现:

使用 parse() 函数:

第一种方法是通过提供要解析的 XML 文件作为参数来使用 parse() 函数。例如:

例子:

from xml.dom import minidom
p1 = minidom.parse("sample.xml");

执行此操作后,您将能够拆分 XML 文件并获取所需的数据。您还可以使用此函数解析打开的文件。

例子:

dat=open('sample.xml')
p2=minidom.parse(dat)

在这种情况下,存储打开文件的变量作为参数提供给解析函数。

使用 parseString() 方法:

当您想要提供要作为字符串解析的 XML 时,将使用此方法。

例子:

p3 = minidom.parseString('<myxml>Using<empty/> parseString</myxml>')

您可以使用上述任何一种方法来解析 XML。现在让我们尝试使用此模块获取数据。

寻找感兴趣的元素:

在我的文件被解析后,如果我尝试打印它,返回的输出会显示一条消息,表明存储解析数据的变量是 DOM 对象。

例子:

dat=minidom.parse('sample.xml')
print(dat)

输出:

<xml.dom.minidom.Document 对象在 0x03B5A308>

使用 GetElementByTagName 访问元素:

例子:

tagname= dat.getElementsByTagName('item')[0]
print(tagname)

如果我尝试使用 GetElementByTagName 方法获取第一个元素,我将看到以下输出:

输出:

<DOM 元素:0xc6bd00 处的项目>

请注意,只返回了一个输出,因为为了方便我使用了 [0] 下标,这将在进一步的示例中删除。

要访问属性的值,我必须按如下方式使用 value 属性:

例子:

dat = minidom.parse('sample.xml')
tagname= dat.getElementsByTagName('item')
print(tagname[0].attributes['name'].value)

输出:  早餐

要检索这些标签中存在的数据,您可以使用 data 属性,如下所示:

例子:


print(tagname[1].firstChild.data)

输出: 纸 Dosa

您还可以使用value属性拆分和检索属性的值。

例子:

print(items[1].attributes['name'].value)

输出: 早餐

要打印出我们菜单中可用的所有项目,您可以遍历这些项目并返回所有项目。

例子:

for x in items:print(x.firstChild.data)

输出:

袖手旁观
纸DOSA
UPMA
碧斯百丽沐浴
Kesari浴

要计算菜单上的项目数,您可以使用 len() 函数,如下所示:

例子:

print(len(items))

输出指定我们的菜单包含 5 个项目。

这使我们结束了本 Python XML 解析器教程。我希望你已经清楚地了解了一切。

点击关注,第一时间了解华为云新鲜技术~

面试官问我:如何在 Python 中解析和修改 XML相关推荐

  1. 了解女友的心还不如了解Python之在Python中解析和修改XML

    2021年12月15日 10:14 ·  阅读 30 摘要: 工作中我们时常需要解析用不同语言编写的数据.Python 提供了许多库来解析或拆分用其他语言编写的数据.在这篇 Python XML 解析 ...

  2. 如何在Python中解析YAML文件

    如何在Python中解析YAML文件? #1楼 不依赖C标头的最简单,最纯净的方法是PyYaml( 文档 ): #!/usr/bin/env pythonimport yamlwith open(&q ...

  3. 面试官问:一个Java字符串中到底能有多少个字符?

    作者 | 鸟窝 来源 | urlify.cn/qYNR3q 依照Java的文档, Java中的字符内部是以UTF-16编码方式表示的,最小值是 \u0000 (0),最大值是\uffff(65535) ...

  4. 当面试官问这些基础的Python问题时,竟然还有80%的人不会!

    怎样才能开始一个交互式解释器的会话? 在Windows下可以通过点击开始按钮,选择"程序",点击"Python",然后选择"Python(comman ...

  5. python 日期解析_如何在Python中解析ISO 8601格式的日期?

    python 日期解析 Python provides a datetime standard library which introduces datetime.isoformat(). As pe ...

  6. 突然就懵了!面试官问我:线程池中多余的线程是如何回收的?

    点击关注公众号,Java干货及时送达 最近阅读了JDK线程池ThreadPoolExecutor的源码,对线程池执行任务的流程有了大体了解,实际上这个流程也十分通俗易懂,就不再赘述了,别人写的比我好多 ...

  7. 面试官问我有环链表中怎么找到入口,本以为很简单当场却想傻了

    链表是否有环问题看似简单,但实际处理上有很多需要注意的,这个问题是非常高频笔试面试题,记忆不牢固容易遗忘,可以认真看看学习一波!有个小伙伴就在某手面试中遇到了. 判断链表是否有环 题目描述: 给定一个 ...

  8. 如何在Python中解析XML?

    我在包含xml的数据库中有很多行,并且我正在尝试编写一个Python脚本,该脚本将遍历这些行并计算出现特定节点属性的实例数量. 例如,我的树看起来像: <foo><bar>&l ...

  9. 【Java8新特性】面试官问我:Java8中创建Stream流有哪几种方式?

    写在前面 先说点题外话:不少读者工作几年后,仍然在使用Java7之前版本的方法,对于Java8版本的新特性,甚至是Java7的新特性几乎没有接触过.真心想对这些读者说:你真的需要了解下Java8甚至以 ...

最新文章

  1. 多个微服务控制台的多窗口展示
  2. golang 生成 解析 json
  3. swift写的摇骰子程序,开源了
  4. 硬件安全(二) 5G时代IOT环境下芯片安全风险与挑战
  5. python爬取新浪新闻首页_学习了《python网络爬虫实战》第一个爬虫,爬取新浪新闻...
  6. 什么是暗物质?有没有理科大神解答一下啊?
  7. puml绘制思维导图_在线绘制流程图, 思维导图
  8. 离线数据系统之oozie详解
  9. 数字孪生智慧运维系统方案
  10. win hook codeproject
  11. 计算机毕设(附源码)JAVA-SSM基于JAVA宠物店管理系统
  12. android绘制半圆弧线_半圆形进度条Android - 绘制半圆
  13. 罗振宇4小时跨年演讲精华版:大环境里的7个行动策略
  14. 044_Unicode对照表十
  15. Android 通过adb禁止某个应用上网
  16. imperva 默认策略添加例外
  17. Thumbnailator的简介和使用范例(图片压缩)
  18. Java中的枚举类型与枚举实现接口的两种方式
  19. gitHub客户端Desktop的安装使用总结 ---基础篇
  20. 卡巴斯基更新新方法(不需要代理服务器)

热门文章

  1. Bootstrap 轮番插件Collapse 调用方式
  2. ROS2官网安装教程补充
  3. Git笔记(7) 撤消操作
  4. java 解析sh文件内容_java 文件读取
  5. matlab圆形器件,计算围绕点+ Matlab的圆形箱
  6. 华为平板wps语音朗读_打工人必备的手机端WPS小技巧
  7. darknet框架_【通知】有三AI发布150页深度学习开源框架指导手册与GitHub项目,欢迎加入我们的开源团队...
  8. java 全排序_Java排序算法全
  9. Linux FTP安装问题
  10. iOS中nil,Nil,NULL的区别