【Python】解析 Xml 格式的文档
xml 文档,无非就是一个树状的数据仓库,最基础的部分也就四个:增删改查。
解析树状结构
- 从硬盘读取
- 从字符串读取
注意:xml.etree.ElementTree模块在应对恶意结构数据时显得并不安全。
from xml.etree import ElementTree
# import data from our dataset
tree = ElementTree.parse([path of xml file])
# pick the root of xml tree
root = tree.getroot()
注意:从字符串读取时不需要parse,因为fromstring直接返回的就是我们的root节点。
from xml.etree import ElementTree
# pick the root of xml tree
root = ElementTree.fromstring(country_data_as_string)
其中,tree比较好理解,就是我们的xml文件的树。root也就是我们的根节点。
root属于element对象,有以下几个属性:
- tag:string对象,表示数据代表的种类。
- attrib:dictionary对象,表示附有的属性。
- text:string对象,表示element的内容。
- tail:string对象,表示element闭合之后的尾迹。
- 若干子元素(child elements)。这些子元素可以通过index索引。
<tag attrib1=1>text</tag>tail
1 2 3 4
小技巧:若想加快速度,可以使用C语言编译的API xml.etree.cElementTree。在import时考虑优先导入,代码修改如下。
try:
import xml.etree.cElementTree as ET
except ImportError:
import xml.etree.ElementTree as ET
ElementTree.Element Class
class xml.etree.ElementTree.Element(tag, attrib={}, **extra)
tag:string,元素代表的数据种类。
attrib:dictionary,元素的属性字典。
text:string,元素的内容。
tail:string,元素的尾形。
# 针对属性的操作
clear():清空元素的后代、属性、text和tail也设置为None。
get(key, default=None):获取key对应的属性值,如该属性不存在则返回default值。
items():根据属性字典返回一个列表,列表元素为(key, value)。
keys():返回包含所有元素属性键的列表。
set(key, value):设置新的属性键与值。
# 针对后代的操作
## 增加新的element
append(subelement):添加直系子元素。
extend(subelements):增加一串元素对象作为子元素。
insert(index, element):在指定位置插入子元素。
## 删除element
remove(subelement):删除子元素。
## 遍历elements,得到iter或者list
find(match):寻找第一个匹配子元素,匹配对象可以为tag或path。
findall(match):寻找所有匹配子元素,匹配对象可以为tag或path。
findtext(match):寻找第一个匹配子元素,返回其text值。匹配对象可以为tag或path。
iter(tag=None):生成遍历当前元素所有后代或者给定tag的后代的迭代器。
iterfind(match):根据tag或path查找所有的后代。
itertext():遍历所有后代并返回text值。
ElementTree Object
class xml.etree.ElementTree.ElementTree(element=None, file=None)
element如果给定,则为新的ElementTree的根节点。
_setroot(element):用给定的element替换当前的根节点。慎用。
getroot():获取根节点。
parse(source, parser=None):装载xml对象,source可以为文件名或文件类型对象。
# 写回方法write
write(file, encoding="us-ascii", xml_declaration=None, default_namespace=None,method="xml")
# 以下方法与Element类中同名方法近似,区别在于它们指定以根节点作为操作对象。
find(match)