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
    评论
Python可以使用多种方式处理XML文件,其一种常用的方式是使用xml.dom.minidom模块。这个模块提供了一些方法来解析、读取、创建和修改XML文件。 首先,你需要导入xml.dom.minidom模块。然后,你可以使用getDOMImplementation()方法获取一个DOM实现对象。接下来,你可以使用createDocument()方法创建一个新的XML文档对象。你需要指定命名空间、根元素和文档类型。例如,你可以使用下面的代码创建一个名为"top"的根元素: from xml.dom.minidom import getDOMImplementation impl = getDOMImplementation() doc_new = impl.createDocument(None, "top", None) 接下来,你可以使用createElement()方法创建其他元素,并使用appendChild()方法将它们添加到根元素。例如,你可以使用下面的代码创建一个名为"content"的元素,并将其添加到根元素: root = doc_new.documentElement content = doc_new.createElement("content") root.appendChild(content) 你还可以使用createTextNode()方法创建文本节点,并使用appendChild()方法将其添加到元素。例如,你可以使用下面的代码创建一个名为"Hello World!"的文本节点,并将其添加到"content"元素: text = doc_new.createTextNode("Hello World!") content.appendChild(text) 最后,你可以使用writexml()方法将编辑后的结果保存到文件。你需要指定文件名、缩进、换行符和编码方式。例如,你可以使用下面的代码将文档保存到名为"new.xml"的文件: with open("new.xml", "w", encoding="utf-8") as f: doc_new.writexml(f, indent='', addindent='\t', newl='\n', encoding="utf-8") 这样,你就可以使用Python处理XML文件了。希望对你有帮助! #### 引用[.reference_title] - *1* *2* *3* [Python处理XML文件](https://blog.csdn.net/Crayonxin2000/article/details/127096473)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值