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

相关推荐
爱勇宝2 分钟前
别再混用了!import.meta.env 与 process.env 的本质差异一次讲透
前端·javascript·vue.js
清粥油条可乐炸鸡6 分钟前
tanstack query的基本使用
前端·axios
路修远i22 分钟前
基于SSE的AI对话流式结构
前端·javascript
攀登的牵牛花42 分钟前
前端向架构突围系列 - 跨端技术 [11 - 1]:JSBridge 原理与 Hybrid设计
前端
用户5757303346241 小时前
从 LocalStorage 待办清单到 CSS 核心机制:一次搞懂数据持久化、继承与盒模型陷阱
前端
codingWhat1 小时前
前端组件库开发实践:从零到发布
前端·npm·vite
cxxcode1 小时前
浏览器模块加载与 Webpack 打包原理
前端
兆子龙1 小时前
React Compiler 来了:少写 useMemo,照样稳
前端·架构
用户5433081441941 小时前
Manifest V3 实战:从补天网站逆向到 Chrome 扩展开发全记录
前端·后端
zhqiok1 小时前
React中类似于Vue中Pinia的轻量级状态管理神器——Zustand
前端