我正在尝试使用XSLT和XPath函数fn:sum在
XML中总结一组值.只要值为非null,这样就可以正常工作,但事实并非如此.为了说明我的问题,我做了一个例子:
<?xml version="1.0"?> <xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fn="http://www.w3.org/2005/xpath-functions"> <xsl:template match="/root"> <root> <!-- Works fine for non-null values --> <sum><xsl:value-of select="fn:sum(values/value)" /></sum> </root> </xsl:template> </xsl:stylesheet>
和XML:
<?xml version="1.0"?> <root> <values> <value>1</value> <value>2</value> <value>3</value> <value>4</value> <!-- Nullvalue --> <value /> </values> </root>
只要没有空值,该示例就可以正常工作.我尝试了各种变体的选择,例如< xsl:value-of select =“fn:sum(values [value!=''] / value)”/> (正如您可能会注意到的,XSLT导出并不多;))如何过滤掉空值?
明确测试节点是否有内容:
<sum><xsl:value-of select="fn:sum(values/value[text()])" /></sum>
我想你提到的是:
<xsl:value-of select="fn:sum(values[value != '']/value)" />
不起作用,因为节点是空的 – 它根本不包含文本节点,而值!=”测试空字符串 – 即具有长度为0的数据的文本节点.