Python中xml处理

 

头文件,常用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)

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值