怎么使用XPath查询XML节点_XPath查询XML节点语法与实例解析

XPath通过路径表达式定位xml节点,核心语法包括/(根节点)、//(任意位置)、@(属性)、*(通配符)及.和..(当前与父节点),结合[ ]条件筛选如索引、属性值、子元素内容等,配合函数实现高效查询。

怎么使用XPath查询XML节点_XPath查询XML节点语法与实例解析

使用XPath查询XML节点,核心在于掌握路径表达式和节点匹配规则。XPath(XML Path Language)是一种在XML文档中查找信息的语言,它通过路径表达式定位节点元素、属性、文本等内容。下面介绍常用语法并结合实例说明如何高效查询XML节点。

基本XPath语法结构

XPath将XML文档视为节点树,支持按层级路径访问节点。常见语法包括:

  • /:从根节点开始选择。例如 /bookstore/book 表示选取根下bookstore中的所有book子节点。
  • //:从任意位置匹配节点。如 //title 会选取文档中所有title元素,无论嵌套多深。
  • @:用于选取属性。例如 //book/@category 获取所有book元素的category属性值。
  • *:通配符,代表任意元素节点。如 /bookstore/* 选取bookstore下的所有子元素。
  • ...:分别表示当前节点和父节点。常用于相对路径中。

按条件筛选节点

使用方括号 [] 添加过滤条件,可精准定位目标节点。

  • 按索引选取://book[1] 选取第一个book节点(注意XPath索引从1开始)。
  • 按属性值匹配://book[@category=’fiction’] 匹配category为fiction的book。
  • 按子元素内容筛选://book[price>30] 选取价格大于30的book节点。
  • 多条件组合://book[@category=’fiction’ and price 同时满足两个条件。

常用函数辅助查询

XPath内置函数能增强查询灵活性。

怎么使用XPath查询XML节点_XPath查询XML节点语法与实例解析

蓝心千询

蓝心千询是vivo推出的一个多功能ai智能助手

怎么使用XPath查询XML节点_XPath查询XML节点语法与实例解析34

查看详情 怎么使用XPath查询XML节点_XPath查询XML节点语法与实例解析

  • text():获取节点文本内容。如 //title/text() 返回title内的文字。
  • contains():模糊匹配字符串。例如 //title[contains(text(),’python’)] 查找标题包含“Python”的节点。
  • starts-with():判断是否以指定字符串开头。//author[starts-with(text(),’John’)] 匹配作者名以John开头的节点。
  • count():统计节点数量,可用于条件判断或验证结果集大小。

实际应用示例

假设有一段XML如下:

 <bookstore>   <book category="fiction">     <title>The Great Gatsby</title>     <author>F. Scott Fitzgerald</author>     <price>15.50</price>   </book>   <book category="science">     <title>A Brief History of Time</title>     <author>Stephen Hawking</author>     <price>35.00</price>   </book> </bookstore> 

对应查询示例:

  • 获取所有书名://title/text()
  • 查找科学类书籍://book[@category=’science’]
  • 获取价格高于30的书的作者://book[price>30]/author/text()
  • 查找作者姓氏含“Hawking”的书名://book[contains(author, ‘Hawking’)]/title/text()

基本上就这些。掌握基础路径、条件筛选和常用函数后,就能灵活应对大多数XML数据提取需求。实际使用时结合工具浏览器控制台、Python的lxml库或XPath测试器,可以快速验证表达式效果。不复杂但容易忽略细节,比如索引从1开始、属性需加@符号等。

上一篇
下一篇
text=ZqhQzanResources