我正在尝试使用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导出不多;))如何过滤掉空值?
答案 0 :(得分:9)
明确测试节点是否有内容:
<sum><xsl:value-of select="fn:sum(values/value[text()])" /></sum>
我认为你提到的是:
<xsl:value-of select="fn:sum(values[value != '']/value)" />
不起作用,因为节点是空的 - 它根本不包含文本节点,而value != ''
测试空字符串 - 即具有长度为0的数据的文本节点。
答案 1 :(得分:6)
仅对包含数字的元素求和:
<sum>
<xsl:value-of select="fn:sum(values/value[number(.)=number(.)])" />
</sum>
对于空元素或字符串值不是数字的元素,number()
的结果为NaN
。
MSDN参考 - http://msdn.microsoft.com/en-us/library/ms256211.aspx
答案 2 :(得分:-2)
http://www.stylusstudio.com/xsllist/199909/post60110.html
<?xml version="1.0"?>
<doc>
<num>1</num>
<num>7</num>
<notnum>hello world</notnum>
<num>4</num>
</doc>
<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/XSL/Transform/1.0">
<xsl:template match="/">
<xsl:value-of select="sum(/doc/num)"/>
</xsl:template>
</xsl:stylesheet>