XPath不支持BETWEEN但可用number()配合比较运算符实现数值范围查询,如//price[number(.)>=50 and number(.)

数值型文本节点的范围查找
假设 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 不支持日期计算。若节点存标准格式日期(如 "2023-05-20"),可按字符串字典序近似比较(仅适用于 ISO 格式且位数固定):
//date[. >= "2023-01-01" and . <= "2023-12-31"]
但这是字符串比较,不是真正的时间范围;严谨场景建议交给程序层解析。
基本上就这些。核心就是用number() + and 拼两个边界条件,简单直接,也兼容绝大多数 XPath 1.0 引擎(如 lxml、Selenium、浏览器开发者工具)。










