XSLT怎么进行数值计算 sum(), count(), number()

10次阅读

XSLT数值计算依赖sum()、count()、number()三函数:sum()对节点集数值求和,遇非数转NaN;count()仅统计节点个数;number()强制类型转换,用于清洗数据。

XSLT怎么进行数值计算 sum(), count(), number()

XSLT 中的数值计算主要通过内置函数实现,sum()count()number() 是最常用三个,但它们用途不同,不能混用。

sum():对节点集中的数值求和

只接受由数字值组成的节点集(如元素或属性),自动把文本内容转为数字再相加。遇到非数字内容会转为 NaN,导致整个结果为 NaN。

  • 正确用法: —— 对所有 price 元素的文本内容求和
  • 注意:如果 price 里含单位(如 “29.99元”),需先用 subString-before 或 replace 清洗,否则 sum() 会返回 NaN
  • 空节点或无文本的元素会被当作 0 处理(前提是能成功转为数字)

count():统计节点数量,不是数值运算

count() 返回的是整数个数,不涉及加减乘除,它和数值计算无关,但常被误认为“求和”。它的参数是节点集,返回该集合中节点的个数。

  • 例如: 输出 item 元素总个数
  • 不能写成 count(//item/price) 来“算价格总数”——它只是数 price 元素有几个,不是加总价格
  • 和 sum() 完全不同类:count() 是聚合计数,sum() 是数值累加

number():强制转为数字,用于清洗和转换

number() 把任意值(字符串、布尔、节点集)转为浮点数,是做数值计算前的关键预处理步骤。

  • 单节点:number(./@discount) 把 discount 属性转为数字(如 “15” → 15)
  • 字符串处理:number(substring-before(./price, '元')) 提取纯数字部分再转换
  • 节点集行为:若传入多节点,只取第一个节点的字符串值再转数字;空节点返回 NaN
  • 常见搭配:常和 sum() 配合使用,比如先用 number() 转每个 price,再用 sum() 累加(不过通常 sum() 内部已隐式调用 number(),直接 sum(//price) 更简洁)

不复杂但容易忽略:sum() 和 number() 都会尝试类型转换,但失败时不报错,而是静默返回 NaN,建议在关键计算前用 string() 检查原始值,或用 xsl:if 判断 number($val) != number($val)(NaN 自身不等于自身)来捕获异常。

text=ZqhQzanResources