头文件,常用ET来处理
import xml.etree.ElementTree as ET
parse解析
#定义一个文件路径
file = '/a/b.xml'
#方法1
root = ET.parse(file).getroot() #实验证明不加getroot也是默认返回root的
#方法2
with open(file,'r') as f:
string = f.read() #只能用read()不能用readlines(),具体区别自行学习
root = ET.fromstring(string)
find查找对应tag名的子对象,有多个存在时返回第一个,不存在时返回None。
folder = root.find('folder')
#对象有三个属性
#.text
#.tag
#.attrib
用findall('name')可以返回所有这个tag名的对象。
遍历所有子对象
for child in root:
print(child.tag, child.attrib)
遍历同tag名的所有子对象
for owner in root.iter('owner'):
print(neighbor.attrib['name'])
以下面这个文件为例。
<annotation>
<folder name='hello'>VOC2007</folder>
<filename>000012.jpg</filename>
<owner>
<flickrid>KevBow</flickrid>
<name>?</name>
</owner>
<owner>
<flickrid>Kevin</flickrid>
<name>?</name>
</owner>
</annotation>
执行ET.parse('bbb.xml').getroot()后,来到<annotation>位置。
执行find('folder')后,来到<folder>位置。
注意,整个<folder></folder>是一个object。
访问.text属性,就是读取内文本,返回str类型的'VOC2007'。
访问 .tag属性,返回str类型的标签'folder'。
访问.attrib属性,返回dict类型的{"name":"hello"}
需要注意的是,仅对最后一层object有text属性。
比如说,本例中的<owner>对象,并不是最后一层,及时find('owner').text也print不出东西。
但是find('filename').text是可以的。
了解上述基本够常用的读取需求了。
修改的话,也很简单
#修改XML文件
root = ET.parse('/aaa/bb.xml')
newEle = ET.Element('NewElement') #创建新对象,tag名为'NewElement'
newEle.text = "New Text" #修改text
newEle.set(key,value) #修改当前element的key属性为value值
root.append(newEle) #为当前root对象添加子元素(newElement)
root.write('/aaa/bb.xml'):更新xml文件
#其他
.insert(index,element)
.remove(subelement)