![](/img/trans.png)
[英]How to use XQuery to count the occurrences of all the elements and attributes in an XML file?
[英]How to count occurrences of attributes using XQuery
我在社交媒体上的一个线程上使用XQuery来计数相关评论的出现。 但是,如果评论是由女性发表的,我只想计算这些发生的次数。 (这是针对Uni的性别相关研究项目。
到目前为止,我已经使用XQuery来计算女性使用此方法发表的所有评论:
for $t in doc ("women.xml")
let $a:=$t//comment/@gender="female"
return count ($a)
但是,我需要一些帮助,以解决如何适应女性所说的外观特定评论的问题。
谢谢您的帮助
首先,请注意
let $a:=$t//comment/@gender="female" return count ($a)
总是返回1。这是因为“ =”的结果是一个布尔值,而布尔值是一个长度为1的序列。
let $a:=$t//comment[@gender="female"] return count ($a)
或更简单
count($t//comment[@gender="female"])
现在,如果您只想定义“外观特定”的注释,则可以
count($t//comment[@gender="female"][local:is-appearance-specific(.)])
然后您需要定义一个函数
declare function local:is-appearance-specific(
$c as element(comment)) as xs:boolean {
....
};
如果评论被视为“外观特定”,则返回true。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.