我使用 xml 和 PHP 创建了一个发票管理系统,但最新的 PHP 版本不支持 XSLT 2.0 - 因此我必须寻找 sum() 替代方案.如何将有效的 xslt 2 函数sum(unitprice *quantity)"转换为 xslt 1.0 ?
I create an invoice management system using xml and PHP but the latest PHP version does not support XSLT 2.0 - therefore I have to look for an sum() alternative. How can I transform the valid xslt 2 function "sum(unitprice * quantity)" to xslt 1.0 ?
XML 内容基于 John 的例子
我用节点集尝试过它,但它不受支持xmlXPathCompOpEval:在中找不到函数节点集"
I tried it with a node-set, but it is not supported "xmlXPathCompOpEval: function node-set not found in"
实际上,sum(price*quantity) 不是有效的 XSLT 2.0 语法.我猜你的意思是类似 `sum(for $x in * return $x/price*$x/quantity).
Actually, sum(price*quantity) isn't valid XSLT 2.0 syntax. I guess you mean something like `sum(for $x in * return $x/price*$x/quantity).
可以通过以下方式对 XSLT 1.0 中的计算值求和:
Summing over a computed value in XSLT 1.0 can be done in the following ways:
两遍解决方案,创建一个节点集,其中节点保存计算值,然后对节点集求和
two pass solution, create a node-set in which the nodes hold the computed values, then sum over the node-set
递归解决方案:编写一个递归模板,将total作为参数,为当前节点加上sum*quantity,然后递归处理剩余的节点
recursive solution: write a recursive template that passes the total so far as a parameter, adds sum*quantity for the current node, then recurses to process the remaining nodes
高阶解决方案:使用 Dimitre Novatchev 的 FXSL 库
higher-order solution: use Dimitre Novatchev's FXSL library
扩展解决方案:使用像saxon:sum()这样的扩展函数
extension solution: use extension functions like saxon:sum()
这篇关于xslt 1 和 sum 函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
在 SELECT(MYSQL/PHP) 中加入 2 个表Joining 2 tables in SELECT(MYSQL/PHP)(在 SELECT(MYSQL/PHP) 中加入 2 个表)
如何使<option selected=“selected">由How to make lt;option selected=quot;selectedquot;gt; set by MySQL and PHP?(如何使lt;option selected=“selectedgt;由 MySQL 和 PHP 设置?)
使用 PHP 中的数组自动填充选择框Auto populate a select box using an array in PHP(使用 PHP 中的数组自动填充选择框)
PHP SQL SELECT where like search item with multiple wordsPHP SQL SELECT where like search item with multiple words(PHP SQL SELECT where like search item with multiple words)
json_encode 从 MSSQL-SELECT 产生 JSON_ERROR_UTF8json_encode produce JSON_ERROR_UTF8 from MSSQL-SELECT(json_encode 从 MSSQL-SELECT 产生 JSON_ERROR_UTF8)
MySQL ORDER BY rand(),名称 ASCMySQL ORDER BY rand(), name ASC(MySQL ORDER BY rand(),名称 ASC)