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

XPath 中用 count() 函数统计节点数量,语法很简单:直接把节点路径作为参数传进去,返回匹配到的节点个数。
基本用法:count(节点路径)
比如要统计 xml 文档中所有 <book></book> 元素的数量:
count(/library/book)
如果文档里有 5 个 <book></book>,这个表达式就返回 5。
常见统计场景和写法
- 统计所有子元素:count(*/book)(当前节点下所有
<book></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() 是标准支持函数。
基本上就这些。记住核心:count 后面括号里必须是一个合法的节点集路径,不是条件也不是值。