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的方法

相关推荐
我叫汪枫3 分钟前
Python 办公自动化入门:玩转 Excel 与 Word
python·word·excel
E_ICEBLUE9 分钟前
三步完成 Markdown 到 Word/PDF 的转换:Python 教程
python·pdf·word·markdown·格式转换
fakaifa31 分钟前
【全开源】智慧共享农场源码独立版+uniapp前端
前端·uni-app·智慧农场·源码下载·智慧农场小程序·智慧共享农场
toooooop838 分钟前
uniapp多个页面监听?全局监听uni.$emit/$on
前端·javascript·uni-app
骨子里的偏爱39 分钟前
【案例】uniapp实现内部信息与外部的html网页双向通信的完整的过程,附加完整的代码部分
前端·uni-app·html
爱泡脚的鸡腿1 小时前
uni-app D4 实战(小兔鲜)
前端·vue.js·架构
星火飞码iFlyCode1 小时前
iFlyCode+SpecKit应用:照片等比智能压缩功能实现
前端·javascript
广白1 小时前
钉钉小程序直传文件到 阿里云OSS
前端·vue.js·uni-app
后台开发者Ethan1 小时前
LangGraph ReAct应用
python·langgraph
f***68601 小时前
问题:Flask应用中的用户会话(Session)管理失效
后端·python·flask