0

我在 xml 中有一个类似于 integer="1,2,3,4,5" 的值。如何使用 XSLT 计算总数。这样输出给我的计数是 5

问候,山姆

4

2 回答 2

0

这是一种方式(可能还有其他方式)。只需将所有逗号转换为空字符串,然后比较字符串长度的差异:

<xsl:value-of 
   select="string-length(@integer) 
           - string-length(translate(@integer, ',', '')) + 1" />

如果你需要处理空字符串,试试这个

<xsl:value-of 
  select="string-length(@integer) 
          - string-length(translate(@integer, ',', '')) 
          + 1 * (string-length(@integer) != 0)" />
于 2012-07-20T07:14:54.953 回答
0

如果您想计算逗号分隔值,但也能够引用单个项目,您可以使用这样的递归模板。

此 XSLT 1.0 样式表会将逗号分隔值转换为节点,然后对它们进行计数...

<xsl:stylesheet version="1.0"
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  xmlns:msxsl="urn:schemas-microsoft-com:xslt">
<xsl:output method="text"/>

<xsl:template match="/">
 <xsl:variable name="as-nodes"> 
  <xsl:call-template name="parse-comma-separated-values">
   <xsl:with-param name="csv" select="t/@csv" />
  </xsl:call-template>
  </xsl:variable>
  <xsl:value-of select="count(msxsl:node-set($as-nodes)/*)" />
</xsl:template>

<xsl:template name="parse-comma-separated-values">
 <xsl:param name="csv" />
 <xsl:choose>
   <xsl:when test="$csv = ''"/>
   <xsl:when test="not( contains( $csv, ','))">
     <value-node value="{$csv}" /> 
   </xsl:when>  
   <xsl:otherwise>
     <value-node value="{substring-before($csv,',')}" /> 
     <xsl:call-template name="parse-comma-separated-values">
      <xsl:with-param name="csv" select="substring-after($csv,',')"/>
     </xsl:call-template>  
   </xsl:otherwise>  
  </xsl:choose>  
</xsl:template>

</xsl:stylesheet>

...应用于此输入文档时...

 <t csv="1,2,3,4,5"/>

...产生...

 5
于 2012-07-20T07:20:08.040 回答