简介

Element类型是一种灵活的容器对象,用于在内存中存储结构化数据。

[注意]xml.etree.ElementTree模块在应对恶意结构数据时显得并不安全。

每个element对象都具有以下属性:

1. tag:string对象,表示数据代表的种类。

2. attrib:dictionary对象,表示附有的属性。

3. text:string对象,表示element的内容。

4. tail:string对象,表示element闭合之后的尾迹。

5. 若干子元素(child elements)。

texttail

1234

创建元素的方法有Element或者SubElement(),前者称作元素的构建函数(constructor),用以构建任一独存的元素;后者称作元素的制造函数(factory function),用以制造某一元素的子元素。

有了一串元素之后,使用ElementTree类来将其打包,把一串元素转换为xml文件或者从xml文件中解析出来。

若想加快速度,可以使用C语言编译的API xml.etree.cElementTree。

导入ElementTree

在使用xml.etree.ElementTree时,一般都按如下导入:

try:

import xml.etree.cElementTree as ET

except ImportError:

import xml.etree.ElementTree asET

XML是中结构化数据形式,在ET中使用ElementTree代表整个XML文档,并视其为一棵树,Element代表这个文档树中的单个节点。

ET对象具有多种方法从不同来源导入数据,如下:

#从硬盘的xml文件读取数据

import xml.etree.ElementTree as ET

tree = ET.parse('country_data.xml')    #载入数据

root = tree.getroot()    #获取根节点

#从字符串读取数据

root = ET.fromstring(country_data_as_string)

[注意]fromstring()是直接获取string对象中的根节点,因此以上root其实是一个Element。

作为一个Element对象,本身是具有子元素,因此可以直接对Element进行迭代取值:

>>>forchildin root:

...  print child.tag, child.attrib

...

country {'name':'Liechtenstein'}

country {'name':'Singapore'}

country {'name':'Panama'}

或者直接使用索引寻找子节点:

>>> root[0][1].text'2008'

Element中的遍历与查询

Element.iter(tag=None):遍历该Element所有后代,也可以指定tag进行遍历寻找。

Element.findall(path):查找当前元素下tag或path能够匹配的直系节点。

Element.find(path):查找当前元素下tag或path能够匹配的首个直系节点。

Element.text: 获取当前元素的text值。

Element.get(key, default=None):获取元素指定key对应的属性值,如果没有该属性,则返回default值。

Element对象

classxml.etree.ElementTree.Element(tag, attrib={}, **extra)

tag:string,元素代表的数据种类。

text:string,元素的内容。

tail:string,元素的尾形。

attrib:dictionary,元素的属性字典。

#针对属性的操作

clear():清空元素的后代、属性、text和tail也设置为None。

get(key,default=None):获取key对应的属性值,如该属性不存在则返回default值。

items():根据属性字典返回一个列表,列表元素为(key, value)。

keys():返回包含所有元素属性键的列表。

set(key, value):设置新的属性键与值。

#针对后代的操作

append(subelement):添加直系子元素。

extend(subelements):增加一串元素对象作为子元素。#python2.7新特性

find(match):寻找第一个匹配子元素,匹配对象可以为tag或path。

findall(match):寻找所有匹配子元素,匹配对象可以为tag或path。

findtext(match):寻找第一个匹配子元素,返回其text值。匹配对象可以为tag或path。

insert(index, element):在指定位置插入子元素。

iter(tag=None):生成遍历当前元素所有后代或者给定tag的后代的迭代器。#python2.7新特性

iterfind(match):根据tag或path查找所有的后代。

itertext():遍历所有后代并返回text值。

remove(subelement):删除子元素。

ElementTree对象

classxml.etree.ElementTree.ElementTree(element=None, file=None)

element如果给定,则为新的ElementTree的根节点。

_setroot(element):用给定的element替换当前的根节点。慎用。

# 以下方法与Element类中同名方法近似,区别在于它们指定以根节点作为操作对象。

find(match)

findall(match)

findtext(match, default=None)

getroot():获取根节点.

iter(tag=None)

iterfind(match)

parse(source, parser=None):装载xml对象,source可以为文件名或文件类型对象.

write(file, encoding="us-ascii", xml_declaration=None, default_namespace=None,method="xml")

模块方法

xml.etree.ElementTree.Comment(text=None)

创建一个特别的element,通过标准序列化使其代表了一个comment。comment可以为bytestring或unicode。

xml.etree.ElementTree.dump(elem)

生成一个element tree,通过sys.stdout输出,elem可以是元素树或单个元素。这个方法最好只用于debug。

xml.etree.ElementTree.fromstring(text)

text是一个包含XML数据的字符串,与XML()方法类似,返回一个Element实例。

xml.etree.ElementTree.fromstringlist(sequence,parser=None)

从字符串的序列对象中解析xml文档。缺省parser为XMLParser,返回Element实例。

New in version 2.7.

xml.etree.ElementTree.iselement(element)

检查是否是一个element对象。

xml.etree.ElementTree.iterparse(source,events=None,parser=None)

将文件或包含xml数据的文件对象递增解析为element tree,并且报告进度。events是一个汇报列表,如果忽略,将只有end事件会汇报出来。

注意,iterparse()只会在看见开始标签的">"符号时才会抛出start事件,因此届时属性是已经定义了,但是text和tail属性在那时还没有定义,同样子元素也没有定义,因此他们可能不能被显示出来。如果你想要完整的元素,请查找end事件。

xml.etree.ElementTree.parse(source,parser=None)

将一个文件或者字符串解析为element tree。

xml.etree.ElementTree.ProcessingInstruction(target,text=None)

这个方法会创建一个特别的element,该element被序列化为一个xml处理命令。

xml.etree.ElementTree.register_namespace(prefix,uri)

注册命名空间前缀。这个注册是全局有效,任何已经给出的前缀或者命名空间uri的映射关系会被删除。

New in version 2.7.

xml.etree.ElementTree.SubElement(parent,tag,attrib={},**extra)

子元素工厂,创建一个Element实例并追加到已知的节点。

xml.etree.ElementTree.tostring(element,encoding="us-ascii",method="xml")

生成一个字符串来表示表示xml的element,包括所有子元素。element是Element实例,method为"xml","html","text"。返回包含了xml数据的字符串。

xml.etree.ElementTree.tostringlist(element,encoding="us-ascii",method="xml")

生成一个字符串来表示表示xml的element,包括所有子元素。element是Element实例,method为"xml","html","text"。返回包含了xml数据的字符串列表。

New in version 2.7.

xml.etree.ElementTree.XML(text,parser=None)

从一个字符串常量中解析出xml片段。返回Element实例。

xml.etree.ElementTree.XMLID(text,parser=None)

从字符串常量解析出xml片段,同时返回一个字典,用以映射element的id到其自身。

欢迎大家加入笔者的软件测试技术交流群1125760266,共同交流探讨

python etree库_python 标准库之xml.etree.ElementTree相关推荐

  1. python的标识库和第三方库_Python 标准库、第三方库

    Python数据工具箱涵盖从数据源到数据可视化的完整流程中涉及到的常用库.函数和外部工具.其中既有Python内置函数和标准库,又有第三方库和工具.这些库可用于文件读写.网络抓取和解析.数据连接.数清 ...

  2. python字符串库函数_Python标准库概览(1):string

    Python的 string 标准库保留了一些有用的函数和用于处理文本对象的类,现在我们来一起看一下Python的string标准库还有哪些我们不知道的有趣用法? 01.capwords()函数:将字 ...

  3. python的threading库_python标准库介绍——31 threading 模块详解

    threading 模块 (可选) ``threading`` 模块为线程提供了一个高级接口, 如 [Example 3-1 #eg-3-1] 所示. 它源自 Java 的线程实现. 和低级的 ``t ...

  4. python自带sqlite库_Python标准库之sqlite3使用实例

    Python自带一个轻量级的关系型数据库SQLite.这一数据库使用SQL语言.SQLite作为后端数据库,可以搭配Python建网站,或者制作有数据存储需求的工具.SQLite还在其它领域有广泛的应 ...

  5. python文件管理包_Python标准库04 文件管理 (部分os包,shutil包)

    Python标准库04 文件管理 (部分os包,shutil包) 在操作系统下,用户可以通过操作系统的命令来管理文件,参考.Python 标准库则允许我们从 Python 内部管理文件.相同的目的,我 ...

  6. python语音识别的第三方库_python标准库+内置函数+第三方库: 7.音频处理

    python标准库+内置函数+第三方库 欲善其事,必先利其器 这其器必是python的标准库+内置函数,话说许多第三方库, 也是对标准库的使用,进行封装,使得使用起来更方便. 这些库以使用场景来分类: ...

  7. python groupby用法_Python 标准库实践之合并字典组成的列表

    作者 | 陈祥安 来源 | Python学习开发 最近做了个数据合并的需求这里记录下: 要求如下: dict_of_list1 = [{"name": "zhangsan ...

  8. print python 带回车_python标准库threading源码解读【二】

    紧接着上一篇文章继续解析源码 甘蔗:python标准库threading源码解读[一]​zhuanlan.zhihu.com 目录 Event的介绍和用法 Event源码解析 以后的内容尽量少一点并且 ...

  9. python lib库_python标准库pathlib常见操作

    pathlib-- 面向对象的文件系统路径 它是python3.4新增的一个标准库,提供了不同操作系统下文件系统路径的操作方式,有两大类一个是纯路径不带I/0操作,另一个可以进行I/0的类.pathl ...

最新文章

  1. [BZOJ2502]清理雪道 有上下界网络流(最小流)
  2. 斯坦福马超:随机梯度下降,也爱躺「平」……why?
  3. MySQL安装步骤及相关问题解决
  4. 15、mybatis一对多关联查询 collection定义关联集合封装规则及懒加载
  5. hdu4099(斐波那契数+字典树)
  6. Boost:序列化之text_iarchive和text_oarchive
  7. figma 安装插件_我制作Figma插件的经验
  8. leetcode97. 交错字符串(动态规划)
  9. Html代码seo优化最佳布局实例讲解
  10. shell中四大循环介绍及使用
  11. 子元素margin-top为何会影响父元素?
  12. 海尔智能微型计算机,微型计算机 Microcomputers
  13. 接口测试搭建之JMeter接口测试与SoapUI接口测试
  14. excel计算数据的差和的公式和方法、相关系数、绝对误差
  15. 4个漂亮的wordpress企业主题
  16. 多源异构数据分析为什么需要数据湖?
  17. python 判断是否有某个属性_python如何判断对象的某个属性
  18. 同元软控助力复杂系统数字孪生落地应用
  19. 已知两角及其夹边,解三角形
  20. 4002 构造数组(可重复组合数问题--隔板法)

热门文章

  1. JavaScript 资源大全中文版
  2. 联想笔记本 ThinkPad T440 Wifi一直掉线的解决方案
  3. 江南爱软装十大品牌 软装也有自己的知识领地
  4. 比亚迪速锐F3专用夏季座套 夏天坐垫 四季坐套
  5. 求掼蛋同花顺代码(Lua)和C++
  6. 仿图书检索系统第二弹jQuery(页面功能)
  7. GNSS测量原理与应用
  8. 雪鹰领主服务器维护,《雪鹰领主》7月11日停机维护更新公告
  9. Elasticsearch Java API 分组、聚合、嵌套相关查询
  10. gg-editor的使用