簡體   English   中英

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

[英]Using fn:sum in XSLT with node-set containing null-values

我試圖使用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>

只要沒有空值,該示例就可以正常工作。 我嘗試過各種各樣的select變體,比如<xsl:value-of select="fn:sum(values[value != '']/value)" /> (你可能會注意到,XSLT並不多) export;))如何過濾掉空值?

明確測試節點是否有內容:

<sum><xsl:value-of select="fn:sum(values/value[text()])" /></sum>

我想你提到的是:

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

不起作用,因為節點是空的 - 它根本不包含文本節點,而value != ''測試空字符串 - 即具有長度為0的數據的文本節點。

僅總結包含數字的元素:

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

對於空元素,或者字符串值不是數字的元素, number()的結果將是NaN

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

http://www.stylusstudio.com/xsllist/199909/post60110.html

XML:

<?xml version="1.0"?>
<doc>
    <num>1</num>
    <num>7</num>
    <notnum>hello world</notnum>
    <num>4</num>
</doc>

XSLT:

<?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>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM