XPath不支持BETWEEN但可用number()配合比较运算符实现数值范围查询,如//price[number(.)>=50 and number(.)XPath 本身不直接支持“范围查询”(比如 SQL 中的 `BETWEEN`),但可以通过组合比较运算符来实现查找**值在某个范围内的节点**,关键在于节点的文本内容能被当作数字处理(即实际是数值型字符串,如 `"123"`、`"45.6"`)。 下面分几种常见情况说明:
假设 XML 中有类似:price 节点:
✅ 正确写法:
//price[number(text()) >= 50 and number(text()) <= 100]
说明:
text() 取出节点的文本内容(如 "89.99")number() 尝试将其转为数字;若转失败(如含字母),结果为 NaN,而 NaN >= 50 为 false,自动被过滤and 连接两个条件,表达“同时满足”如果节点只含数字且无空格/单位,可省略 text()(XPath 1.0 中,对元素节点用 number(.) 等价于 number(string(.))):
//price[number(.) >= 50 and number(.) <= 100]
⚠️ 注意:如果节点含空格或单位(如 ),需先清理再转换,XPath 1.0 本身不支持正则,得靠外部处理;XPath 2.0+ 可用 replace():
//price[number(replace(., '[^0-9.]', '')) >= 50 and number(replace(., '[^0-9.]', '')) <= 100]
比如查找 age 属性在 18–65 的 person 元素:
//person[number(@age) >= 18 and number(@age) <= 65]
同样依赖 number() 安全转换;若属性可能为空或非数字,该表达式会跳过无效项。
XPath 1.0 不支持日期计算。
若节点存标准格式日期(如 "2025-05-20"),可按字符串字典序近似比较(仅适用于 ISO 格式且位数固定):
//date[. >= "2025-01-01" and . <= "2023-12-31"]
但这是字符串比较,不是真正的时间范围;严谨场景建议交给程序层解析。
基本上就这些。核心就是用number() + and 拼两个边界条件,简单直接,也兼容绝大多数 XPath 1.0 引擎(如 lxml、Selenium、浏览器开发者工具)。