【XML基本概念介绍】

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

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

概念一:

复制代码 代码如下:

# foo元素的起始标签

# foo元素的结束标签

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

概念二:

复制代码 代码如下:

# 元素可以嵌套到任意参次

# bar元素为foo元素的子元素

# 父元素foo的结束标签

概念三:

复制代码 代码如下:

# foo元素有个lang的属性,该属性值为: EN;对应Python字典(Name-Value)对;

# bar元素有个lang的属性,该属性值为: CH;还有个id属性,值为:001,放置在''或“”中;

# bar元素中的lang属性不会和foo元素中相冲突,每个元素都有独立的属性集;

概念四:

复制代码 代码如下:

Learning Python # 元素可以有文本内容

# Note:如果一个元素即没有文本内容,也没有子元素,则为空元素。

概念五:

复制代码 代码如下:

# info元素为根节点

A            # list元素为子节点

B

C

概念六:

复制代码 代码如下:

# 可以通过声明xmlns来定义默认名字空间,feed元素处于http://www.w3.org/2005/Atom命名空间中

dive into mark             # title元素也是。名字空间声明不仅会作用于当前声明它的元素,还会影响到该元素的所有子元素

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

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

# feed属于命名空间atom

dive into mark             # title元素同样属于该命名空间

# xmlns(XML Name Space)

【XML几种解析方法】

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

Python有三种方法解析XML: SAX,DOM,以及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

复制代码 代码如下:

Book message

python check

001

200

python learn

002

300

###########

##  加载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

==============================

PS:这里再为大家提供几款关于xml操作的在线工具供大家参考使用:

在线XML/JSON互相转换工具:http://tools.jb51.net/code/xmljson

在线格式化XML/在线压缩XML:http://tools.jb51.net/code/xmlformat

XML在线压缩/格式化工具:http://tools.jb51.net/code/xml_format_compress

本文标题: Python中使用ElementTree解析XML示例

本文地址: http://www.cppcns.com/jiaoben/python/125735.html

python解析xml文件elementtree_Python中使用ElementTree解析XML示例相关推荐

  1. python解析xml文件elementtree_Python XML解析之ElementTree

    参考网址: 菜鸟教程提供了基本的XML编程接口DOM.SAX,以及轻量级ElementTree的简易概念说明和一些示例.DOM是一种跨语言的XML解析机制,通过将整个XML在内存中解析为一个树来操作, ...

  2. python中使用ElementTree 操作XML

    概述 参考elementTree的官方文档,ET 模块可以归纳为三个部分:ElementTree类,Element类以及一些操作 XML 的函数.  XML是一种固有的分层数据格式,表示它的最自然的方 ...

  3. python解析xml文件选用模块_python语言解析xml文件的常用的有两种方式

    MiniDom方式解析xml xml文件以data.xml为例,具体操作如下: data.xml: 保存用户的信息 Jordy 12345678 20 男 上网 功夫 34443678 18 男 功夫 ...

  4. 【Android 逆向】使用 Python 代码解析 ELF 文件 ( PyCharm 中进行断点调试 | ELFFile 实例对象分析 )

    文章目录 一.PyCharm 中进行断点调试 二.ELFFile 实例对象分析 一.PyCharm 中进行断点调试 在上一篇博客 [Android 逆向]使用 Python 代码解析 ELF 文件 ( ...

  5. java dom xml 换行,dom4j解析xml文件_用DOM解析XML文件,怎么才能让解析出来的文本不用换行_dom解析xml文件...

    网友求助:dom4j解析xml文件_用DOM解析XML文件,怎么才能让解析出来的文本不用换行_dom解析xml文件 问题importjava.text.SimpleDateFormat; import ...

  6. Tomcat7.0源码分析——server.xml文件的加载与解析

    前言 作为Java程序员,对于Tomcat的server.xml想必都不陌生.本文基于Tomcat7.0的Java源码,对server.xml文件是如何加载和解析进行分析. 加载过程分析 Bootst ...

  7. Castor 解析xml文件报错org.exolab.castor.xml.MarshalException

    Castor 解析xml文件报错org.exolab.castor.xml.MarshalException: Illegal Text data found as child of org.exol ...

  8. Mybatis - xml文件标签中写注释

    Mybatis - xml文件标签中写注释 1.错误场景. ( /* */ 注释 ) 在IDEA中的直接使用快捷键注释 Ctrl + Shift + / 注释. SELECT t.name, t.ag ...

  9. java解析dxf文件_浅析JVM方法解析、创建和链接

    一:前言 上周末写了一篇文章<你知道Java类是如何被加载的吗?>,分析了HotSpot是如何加载Java类的,干脆趁热打铁,本周末再来分析下Hotspot又是如何解析.创建和链接类方法的 ...

最新文章

  1. 用LIBSVM做回归和预测
  2. linux 生成o 文件,急,linux为什么生成不了.o驱动程序文件
  3. C#怎么遍历一个对象里面的全部属性?
  4. python创建sqlite3数据库_Python之Sqlite3数据库基本操作
  5. react的一些思考
  6. 第三次学JAVA再学不好就吃翔(part112)--内存输出流
  7. 干货|MIT线性代数课程精细笔记[第一课]
  8. Apache ab 压力测试工具
  9. sigv linux 信号,LINUX 信号处理
  10. 8. 额外的并发实用程序(Additional Concurrency Utilities)
  11. Oracle监控指标
  12. Aspose.word保存PDF时进行授权访问设置
  13. mysql结构改写为hbase表_sqlite数据库修改表结构
  14. Keystore was tampered with or password was incorrect
  15. 织梦html的网站地图怎么制作,网站地图如何制作?网站地图的制作与提交方法...
  16. Unity基础-灯光
  17. 蓝牙BLE方案|智能穿戴市场持续火热,伦茨科技推出智能手表方案
  18. 商标遭遇侵权,企业该如何反击?
  19. 环信群列表 php,一行代码实现群聊头像(用环信仿微信群聊头像)
  20. hutool导出excel 设置单元格日期格式 poi设置excel单元格日期格式

热门文章

  1. 解决nginx 504 Gateway Time-out的一些方法
  2. Go性能测试benchmark
  3. python 系统托盘_使用 PySide 实现 Python 系统托盘图示
  4. c语言的多线程,如何用C语言实现多线程
  5. windows常用的几个操作
  6. xposed框架在分机安装失败_免root用Xposed框架!安卓用户一定要学会
  7. PHP 每小时抽奖,php分时间段的抽奖程序代码
  8. 上网课的心得体会1000字_【家庭教育】家庭教育心得体会 ——济南市罗而小学家庭教育“好家风好家教”专栏(十一)...
  9. macos 安装python3.8 版本_用python安装cutadapt程序
  10. mysql jdbc url设置时区