Python中用ElementTree解析XML

XML基本概念介绍

XML 指可扩展标记语言(eXtensible Markup Language)。

XML 被设计用来传输和存储数据。

概念一:

<foo>      # foo元素的起始标签
</foo>     # foo元素的结束标签
           # note: 每一个起始标签必须有对应的结束标签来闭合, 也可以写成<foo/>

概念二:

<foo>           # 元素可以嵌套到任意参次
  <bar></bar>   # bar元素为foo元素的子元素
</foo>          # 父元素foo的结束标签

概念三:

<foo lang='EN'>                  # foo元素有个lang的属性,该属性值为: EN;对应Python字典(Name-Value)对;
  <bar id='001' lang="CH"></bar> # bar元素有个lang的属性,该属性值为: CH;还有个id属性,值为:001,放置在''或“”中;
</foo>                           # bar元素中的lang属性不会和foo元素中相冲突,每个元素都有独立的属性集;

概念四:

<title>Learning Python</title> # 元素可以有文本内容
                                # Note:如果一个元素即没有文本内容,也没有子元素,则为空元素。

概念五:

<info>                                  # info元素为根节点
    <list id='001'> A </list>           # list元素为子节点
    <list id='002'> B </list>
    <list id='003'> C </list>
</info>

概念六:

<feed xmlns='http://www.w3.org/2005/Atom'>  # 可以通过声明xmlns来定义默认名字空间,feed元素处于http://www.w3.org/2005/Atom命名空间中
  <title>dive into mark</title>             # title元素也是。名字空间声明不仅会作用于当前声明它的元素,还会影响到该元素的所有子元素
</feed>

也可以通过xmlns:prefix声明来定义一个名字空间并取其名为prefix。

然后该名字空间中的每个元素都必须显式地使用这个前缀(prefix)来声明。

<atom:feed xmlns:atom='http://www.w3.org/2005/Atom'>  # feed属于命名空间atom
  <atom:title>dive into mark</atom:title>             # title元素同样属于该命名空间
</atom:feed>                                          # xmlns(XML Name Space)

XML几种解析方法

常见的XML编程接口有DOM和SAX,这两种接口处理XML文件的方式不同,使用场合自然也就不同。

Python有三种方法解析XML: SAXDOM,以及ElementTree:

1.SAX (Simple API for XML )

Pyhton标准库包含SAX解析器,SAX用事件驱动模型,通过在解析XML的过程中触发一个个的事件并调用用户定义的回调函数来处理XML文件。SAX是一种基于事件驱动的API。利用SAX解析XML文档牵涉到两个部分:解析器和事件处理器。

解析器负责读取XML文档,并向事件处理器发送事件,如元素开始及结束事件;而事件处理器则负责对事件作出处理。

优点:SAX流式读取XML文件,比较快,占用内存少。

缺点:需要用户实现回调函数(handler)。

2.DOM(Document Object Model)

将XML数据在内存中解析成一个树,通过对树的操作来操作XML。一个DOM的解析器在解析一个XML文档时,一次性读取整个文档,把文档中所有元素保存在内存中的一个树结构里,之后你可以利用DOM提供的不同的函数来读取或修改文档的内容和结构,也可以把修改过的内容写入xml文件。

优点:使用DOM的好处是你不需要对状态进行追踪,因为每一个节点都知道谁是它的父节点,谁是子节点.

缺点:DOM需要将XML数据映射到内存中的树,一是比较慢,二是比较耗内存,使用起来也比较麻烦!

3.ElementTree(元素树)

ElementTree就像一个轻量级的DOM,具有方便友好的API。代码可用性好,速度快,消耗内存少。

相比而言,第三种方法,即方便,又快速,我们一直用它!下面介绍用元素树如何解析XML:

ElementTree解析

两种实现

ElementTree生来就是为了处理XML ,它在Python标准库中有两种实现。

一种是纯Python实现,例如: xml.etree.ElementTree

另外一种是速度快一点的:   xml.etree.cElementTree

尽量使用C语言实现的那种,因为它速度更快,而且消耗的内存更少! 在程序中可以这样写:

try:
    import xml.etree.cElementTree as ET
except ImportError:
    import xml.etree.ElementTree as ET

常用方法

# 当要获取属性值时,用attrib方法。
# 当要获取节点值时,用text方法。
# 当要获取节点名时,用tag方法。

示例XML

<?xml version="1.0" encoding="utf-8"?>
<info>
   <intro>Book message</intro>
    <list id='001'>
        <head>bookone</head>
        <name>python check</name>
        <number>001</number>
        <page>200</page>
    </list>
    <list id='002'>
        <head>booktwo</head>
        <name>python learn</name>
        <number>002</number>
        <page>300</page>
    </list>
</info>

###########

##  加载XML

###########

方法一:加载文件

root = ET.parse('book.xml')

方法二:加载字符串

root = ET.fromstring(xmltext)

###########

## 获取节点

###########

方法一:获得指定节点->getiterator()方法

book_node = root.getiterator('list')

方法二:获得指定节点->findall()方法

book_node = root.findall('list')

方法三:获得指定节点->find()方法

book_node = root.find('list')

方法四:获得儿子节点->getchildren()

for node in book_node:
    book_node_child = node.getchildren()[0]
    print book_node_child.tag, '=> ', book_node_child.text

###########

##  例子01

###########

# coding=utf-8

try:                                           # 导入模块
    import xml.etree.cElementTree as ET
except ImportError:
    import xml.etree.ElementTree as ET

root   = ET.parse('book.xml')                 # 分析XML文件
books  = root.findall('/list')                # 查找所有根目录下的list的子节点
for book_list in books:                       # 对查找后的结果遍历
    print "=" * 30                            # 输出格式
    for book in book_list:                    # 对每个子节点再进行遍历,找出里面你的属性及值
        if book.attrib.has_key('id'):         # 一句id来做条件判断
            print "id:", book.attrib['id']    # 根据id打印出属性值
        print book.tag + '=> ' + book.text    # 输出标签及文本内容
print "=" * 30

输出结果:

==============================
head=> bookone
name=> python check
number=> 001
page=> 200
==============================
head=> booktwo
name=> python learn
number=> 002
page=> 300
==============================
时间: 2024-12-10 23:05:22

Python中用ElementTree解析XML的相关文章

Python使用ElementTree解析XML【译】

19.7. xml.etree.ElementTree — The ElementTree XML API 源代码: Lib/xml/etree/ElementTree.py Element类型是一种灵活的容器对象,用于在内存中存储层次数据结构.可以说是list和dictionary的交叉. 注意: xml.etree.ElementTree 模块对含有恶意代码的数据是不安全的.如果你想处理不信任的数据请使用 XML vulnerabilities. 每个element都有一系列相关属性: 标签

python使用ElementTree解析XML文件

一.将XML网页保存到本地 要加载XML文件首先应该将网页上的信息提取出来,保存为本地XML文件.抓取网页信息可以python的urllib模块. 代码如下: from urllib import urlopen url = "http://********/**" resp = urlopen(url).read() f = open('文件保存路径', 'w') f.write(resp) f.close() 二.解析XML文件 python有许多可以用来解析XML文件的函数,在这

python 使用ElementTree解析xml

以country.xml为例,内容如下: <?xml version="1.0"?> <data> <country name="Liechtenstein"> <rank updated="yes">2</rank> <year>2008</year> <gdppc>141100</gdppc> <neighbor name=&qu

python中用lxml解析html

lxml,是python中用来处理xml和html的功能最丰富和易用的库.详情见:http://lxml.de/index.html. 在windows下安装lxml,可以用easy_install工具,也可以直接安装二进制文件.为了方便,我选择直接用二进制方式安装. 二进制文件的下载页面:https://pypi.python.org/pypi/lxml/3.4.1 选择合适的版本,因我的系统是win7,64位,python版本为2.7,所以我选择如下lxml版本. 安装完成后,就可以开始py

Python_xml模块_用ElementTree解析xml

xml: 可扩展标记语言,用来标记数据,定义数据类型,主要用来传输和存储数据(和json差不多,不同语言或程序之间进行数据交换的协议) xml格式: <site> <name>hello</name> <url>yeah</url> </site> <site> <name>你好</name> <url>嘿</url> </site> 用ElementTree解析

python中用ElementTree.iterparse()读取xml文件中的多层节点

我在使用Python解析比较大型的xml文件时,为了提高效率,决定使用iterparse()方法,但是发现根据网上的例子:每次if event == 'end':之后elem.clear()或者是每次 if elem.tag == '':之后clear(),都只能去到当前标签的相关内容,如果想继续读取得到标签的子标签,则会返回为空,也就是取不到. 其实iterparse()方法的原理是当遇到标签的“>”符号时触发start,当遇到标签的结束标志是会触发end,比如: <item> <

python xml.etree.ElementTree解析xml文件获取节点

<?xml version = "1.0" encoding = "utf-8"?> <root> <body name="lyc"> <age>110</age> </body> <body name = "l" age = "10"> </body> </root> ###############

Python使用ElementTree处理xml文件

在Python中一般情况我们应该使用ElementTree处理xml文件,ElementTree从Python 2.5开始成为标准模块.一般情况指的是: XML 文件大小适中,对性能要求并非非常严格. 下面讲解如何通过ElementTree来操作XML: 1.引入库 需要用到3个类,ElementTree,Element以及建立子类的包装类SubElement try: import xml.etree.cElementTree as ET except ImportError: import

python使用SAX解析xml

python 标准库包含SAX解析器,SAX用事件驱动模型,通过在解析XML的过程中触发一个个的事件并调用用户定义的回调函数来处理XML文件 在python中使用sax方式处理xml要先引入xml.sax中的parse函数,还有xml.sax.handler中的ContentHandler ContentHandler类方法介绍 # characters(content)方法# 调用时机:# 从行开始,遇到标签之前,存在字符,content的值为这些字符串.# 从一个标签,遇到下一个标签之前,