我正在尝试使用 XSLT 和 XPath 函数 fn:sum 对 XML 中的一组值求和。只要值非空,这种方法就可以正常工作,但事实并非如此。为了说明我的问题,我举了一个例子:
<?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)" />
不起作用,因为该节点是空的 - 它根本不包含文本节点,而value != ''
测试空字符串 - 即数据长度为 0 的文本节点。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)