Python提取xml节点

xml.etree.ElementTree 是 Python 标准库中的模块,用于解析和处理 XML 数据。它提供了一种简单的方式来解析 XML 文件并将其表示为树结构,使得可以方便地遍历和操作 XML 数据。

要使用 xml.etree.ElementTree 模块,你可以导入它并使用其中的函数和类来处理 XML 数据。以下是一些常见的操作:

  1. xml.etree.ElementTree.parse(file):解析 XML 文件并返回一个树对象。
  2. xml.etree.ElementTree.Element:表示 XML 元素的类。
  3. Element.find(tag):在当前元素的子元素中搜索指定标签的第一个匹配项。
  4. Element.findall(tag):在当前元素的子元素中搜索所有匹配指定标签的项。
  5. Element.text:获取元素的文本内容。
  6. Element.attrib:获取元素的属性字典。

这些功能可以帮助你在 Python 中处理 XML 数据,例如解析 XML 文件、提取特定标签的内容、修改 XML 结构等。

对于以下xml内容,需要获取Progress中的内容

xml 复制代码
<Log>
			<Progress>C:\Users\lenovo\Desktop\Progress.txt</Progress>
			<Error>C:\Users\lenovo\Desktop\Error.txt</Error>
</Log>
python 复制代码
import xml.etree.ElementTree as ET
tree = ET.parse(xml_path)
root = tree.getroot()
progress = root.find(".//Log/Progress")
progress_content=progress.text

使用find方法获取节点,且注意父节点.//,子节点/。使用.text提取文本

而对于xml中含有的多个相同结构的子节点

xml 复制代码
<Inputs ParameterNum="2">				                   
		    <Parameter>
			    <ParaName>InputndviPath</ParaName>			     
			    <ParaChsName>tiff格式ndvi</ParaChsName>
			    <ParaType>File</ParaType>			           
			    <DataType>tiff</DataType>  			           
			    <ParaSource>Cal</ParaSource>		     
			    <ParaValue>F:\土壤水分算法封装\exe\ndvi.tif</ParaValue>
			    <OptionValue>DEFAULT</OptionValue>			         
			    <filePath>DEFAULT</filePath>
			</Parameter>
			<Parameter>
				<ParaName>InputlstPath</ParaName>
				<ParaChsName>tiff格式lst</ParaChsName>
				<ParaType>File</ParaType>
				<DataType>tiff</DataType>
				<ParaSource>Cal</ParaSource>
				<ParaValue>F:\土壤水分算法封装\exe\lst.tif</ParaValue>
				<OptionValue>DEFAULT</OptionValue>
				<filePath>DEFAULT</filePath>
			</Parameter>
		</Inputs>
python 复制代码
tree = ET.parse(xml_path)
root = tree.getroot()
 inputs = root.find(".//Inputs")
        parameter_num_inputs = inputs.get("ParameterNum")
        inputs_para_value = []
        for parameter in inputs.findall("Parameter"):
            inputs_para_value.append(parameter.find("ParaValue").text)  # 获取参数
        ndvipath = str(inputs_para_value[0])  # 影像路径
        lstpath = str(inputs_para_value[1])

可以使用findall的方法

相关推荐
sbjdhjd7 小时前
Redis 主从复制、哨兵高可用与 Cluster 集群部署实验手册
运维·前端·redis·云原生·开源·bootstrap·html
乐兮创想 小林7 小时前
企业官网移动端性能优化实战:从 Core Web Vitals 到图片/CDN/响应式的工程清单
前端·性能优化·网站建设·北京网站建设公司
前端一小卒8 小时前
不手写代码的第 30 天,我才明白前端这个岗位还剩什么
前端·javascript·ai编程
Ajie'Blog8 小时前
Copilot Agent Tasks API 开放:AI 编程开始进入后台任务时代
服务器·前端·javascript·人工智能·copilot·ai编程
世辰辰辰8 小时前
批量修改图片/文本名子
开发语言·python·批量修改文件名
老毛肚8 小时前
jeecgboot vue TS & 模板化 04
前端·javascript·vue.js
AI_零食9 小时前
鸿蒙PC Electron跨平台应用开发:24时区时间表应用详解
前端·华为·electron·开源·harmonyos·鸿蒙
myenjoy_19 小时前
MQTT 与 Sparkplug B——从车间到云端的最后一公里
网络·python
Electrolux10 小时前
[onlyoffice-v9]纯前端怎么实现编辑预览office
前端·javascript·github
码云之上10 小时前
聊聊如何设计一个高效、稳定的 Node.js 接入层
前端·后端·node.js