0

0

怎么用XSLT计算XML节点总数和平均值 sum() count()

星降

星降

发布时间:2025-12-29 16:24:08

|

656人浏览过

|

来源于php中文网

原创

XSLT 1.0 中计算节点平均值需用 sum() div count() 手动实现,配合 format-number() 控制精度,并用 xsl:choose 防除零;count() 统计节点数,sum() 求和(需确保内容可转数字)。

怎么用xslt计算xml节点总数和平均值 sum() count()

用 XSLT 计算 XML 节点总数和平均值,核心是用 sum()count() 函数,再配合除法即可得到平均值。注意:XSLT 1.0 不支持 avg()(那是 XSLT 2.0+ 才有的),所以必须手动算 sum() div count()

计算指定节点的总数(count)

count() 统计匹配到的节点个数。比如统计所有 元素的数量:

说明:

  • //price 表示文档中任意位置的 元素;
  • 如果只统计某一层(如 book/price),就写具体路径,避免误统计;
  • 若没有匹配节点,count() 返回 0 —— 后续算平均值时需防除零错误。

计算数值节点的总和(sum)

sum() 对节点集里每个节点的字符串值转为数字后求和。要求节点内容可转为数字(如 "19.99" 可以,"free" 或空字符串会变成 NaN):

常见处理技巧:

  • 过滤掉非数字内容:用 number(.) != number(.) 判 NaN(不推荐),更稳妥的是先用 string(.) != '' and number(.) = number(.) 筛有效数字;
  • 确保只取文本内容:写成 sum(//price/text()) 更明确(但多数情况 //price 已隐含取其字符串值);
  • 如果 price 带单位(如 $25.50),需用 translate() 或正则(XSLT 2.0+)预处理。

手动计算平均值(sum div count)

XSLT 1.0 中没有 avg(),所以平均值 = 总和 ÷ 个数。关键要避免除零:

笔灵AI论文写作
笔灵AI论文写作

免费生成毕业论文、课题论文、千字大纲,几万字专业初稿!

下载

  
    
  
  0

说明:

  • div 是 XSLT 中的除法运算符(不是 /);
  • 结果默认保留小数,如需保留两位小数,XSLT 1.0 可用 format-number(sum(...) div count(...), '0.00')
  • XSLT 2.0+ 可直接写 avg(//price),更简洁且自动跳过非数字节点。

完整示例:XML + XSLT 片段

假设 XML 有:


  29.99
  15.50
  32.00

对应 XSLT 输出统计:


  总数:
总和:
平均:

输出效果:

总数:3
总和:77.49
平均:25.83

基本上就这些。重点记牢:XSLT 1.0 用 sum() div count() 算平均,加 format-number() 控制精度,用 xsl:choose 防除零 —— 不复杂但容易忽略细节。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1429

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

221

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

69

2025.10.17

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.11.20

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

426

2024.06.27

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1846

2024.04.01

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

121

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.1万人学习

Sass 教程
Sass 教程

共14课时 | 0.7万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号