在XSLT中使用fn:sum,其中包含包含空值的节点集

lar*_*moa 7 xml xslt xpath

我试图使用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>
Run Code Online (Sandbox Code Playgroud)

和XML:

<?xml version="1.0"?>
<root>
  <values>
    <value>1</value>
    <value>2</value>
    <value>3</value>
    <value>4</value>
    <!-- Nullvalue -->
    <value />
  </values>
</root>
Run Code Online (Sandbox Code Playgroud)

只要没有空值,该示例就可以正常工作.我已经尝试了各种变量的选择,例如<xsl:value-of select="fn:sum(values[value != '']/value)" />(你可能会注意到,XSLT导出不多;))如何过滤掉空值?

Rol*_*man 10

明确测试节点是否有内容:

<sum><xsl:value-of select="fn:sum(values/value[text()])" /></sum>
Run Code Online (Sandbox Code Playgroud)

我想你提到的是:

<xsl:value-of select="fn:sum(values[value != '']/value)" /> 
Run Code Online (Sandbox Code Playgroud)

不起作用,因为节点是空的 - 它根本不包含文本节点,而value != ''测试空字符串 - 即具有长度为0的数据的文本节点.


Lac*_*che 7

仅总结包含数字的元素:

<sum>
    <xsl:value-of select="fn:sum(values/value[number(.)=number(.)])" />
</sum>
Run Code Online (Sandbox Code Playgroud)

结果number()将是NaN空元素或字符串值不是数字的元素.

MSDN参考 - http://msdn.microsoft.com/en-us/library/ms256211.aspx