count()函数用于统计XPath匹配的节点数量,语法为count(节点路径),如count(/library/book);需确保参数为节点集而非字符串或布尔值,实际使用时注意返回类型转换。

XPath 中用 count() 函数统计节点数量,语法很简单:直接把节点路径作为参数传进去,返回匹配到的节点个数。
基本用法:count(节点路径)
比如要统计 XML 文档中所有 元素的数量:
如果文档里有 5 个 ,这个表达式就返回 5。
常见统计场景和写法
- 统计所有子元素:count(*/book)(当前节点下所有
) - 带条件统计:count(//book[@category='fiction'])(统计 category 属性为 fiction 的 book)
- 统计文本不为空的节点:count(//title[string-length(normalize-space()) > 0])
- 统计某个父节点下的子节点数:count(/library/book/author)(每个 book 下的 author 总数)
注意事项
count() 返回的是整数,不能直接用于字符串拼接或比较节点本身;它只认节点集,不接受字符串或布尔值。
- 错误写法:count('abc')(字符串不是节点集)
- 错误写法:count(//book/title = 'XML Guide')(这是布尔表达式,不是节点路径)
- 正确思路:先写对路径,再套 count(),例如想看有没有标题是 XML Guide 的书,应该用 //book[title='XML Guide'],而不是 count() 里面做判断
在实际工具中怎么用
在浏览器控制台、XMLSpy、或者 Python 的 lxml 库里调用 XPath 时,count() 是标准支持函数。
- Chrome 控制台:$x("count(//item)")
- Python lxml:tree.xpath("count(//book)")(注意返回 float 类型,需 int() 转换)
基本上就这些。记住核心:count 后面括号里必须是一个合法的节点集路径,不是条件也不是值。










