Arrays 如何在XSLT中从数组中提取所有值?

Arrays 如何在XSLT中从数组中提取所有值?,arrays,xml,xslt,Arrays,Xml,Xslt,我有变量(数组)[123456789]。我需要提取所有的值和输出。我正在使用XSLT2.0 示例输入XML <xsl:param name="pNumbers" select="'[123, 456, 789]'" /> <xsl:template match="Response"> <xsl:copy-of select="."/> <xsl:element name="Numbers"> <xsl:e

我有变量(数组)[123456789]。我需要提取所有的值和输出。我正在使用XSLT2.0

示例输入XML

<xsl:param name="pNumbers" select="'[123, 456, 789]'" />

<xsl:template match="Response">
    <xsl:copy-of select="."/>
      <xsl:element name="Numbers">
        <xsl:element name="Number">
              <xsl:value-of select="$pNumbers"/>
        </xsl:element>
      </xsl:element>
</xsl:template>

我需要得到

           <Numbers>
                <Number>
                  123
              </Number>
                <Number>
                  456
              </Number>
                <Number>
                  789
              </Number>
          </Numbers>
<Numbers>
   <Number>123</Number>
   <Number>456</Number>
   <Number>789</Number>
</Numbers>

123
456
789
此外,该值可以是数组中的一个-[123]

       <Numbers>
            <Number>
              123
          </Number>
      </Numbers>

123
使用xsl:for-each并没有实现这一点

Upd:

差不多,但不是最后一个元素

<xsl:template name="split">
   <xsl:param name="str" select="."/>
    <xsl:choose>
      <xsl:when test="contains($str, ',')">
        <xsl:element name="Number">
          <xsl:value-of select="normalize-space(substring-before($str, ','))"/>
        </xsl:element>
        <xsl:call-template name="split">
          <xsl:with-param name="str" select="substring-after($str, ',')"/>
        </xsl:call-template>
      </xsl:when>
      <xsl:otherwise>
        <xsl:element name="Number">
            <xsl:value-of select="$pNumbers"/>
        </xsl:element>
      </xsl:otherwise>
    </xsl:choose>
  </xsl:template>

Upd2

解决了XSLT1.0。谢谢

<xsl:template name="split">
     <xsl:param name="str" select="."/>
      <xsl:choose>
        <xsl:when test="contains($str, ',')">
          <xsl:element name="Number">
            <xsl:value-of select="normalize-space(substring-before($str, ','))"/>
          </xsl:element>
          <xsl:call-template name="split">
            <xsl:with-param name="str" select="substring-after($str, ',')"/>
          </xsl:call-template>
        </xsl:when>
        <xsl:otherwise>
          <xsl:element name="Number">
              <xsl:value-of select="normalize-space($str)"/>
          </xsl:element>
        </xsl:otherwise>
      </xsl:choose>
    </xsl:template>

    <xsl:template match="Numbers">
                <xsl:element name="Number">
                                  <xsl:call-template name="split">
                <xsl:with-param name="str" select="substring-before(
                                                  substring-after(
                                                  $pNumber, '[' )
                                                  ,']' )" />
              </xsl:call-template>
            </xsl:element>
    </xsl:template>

如果(看起来)您的参数是字符串,则需要对其进行标记。在XSLT 2.0中,这比您开始做的要简单得多:

XSLT2.0

<xsl:stylesheet version="2.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>

<xsl:param name="pNumbers" select="'[123, 456, 789]'" />

<xsl:template match="/">
    <Numbers>
        <xsl:for-each select="tokenize(substring($pNumbers, 2, string-length($pNumbers) - 2), ', ')">
            <Number>
                <xsl:value-of select="."/>
            </Number>
        </xsl:for-each>
    </Numbers>
</xsl:template>

</xsl:stylesheet>

结果

           <Numbers>
                <Number>
                  123
              </Number>
                <Number>
                  456
              </Number>
                <Number>
                  789
              </Number>
          </Numbers>
<Numbers>
   <Number>123</Number>
   <Number>456</Number>
   <Number>789</Number>
</Numbers>

123
456
789

如果可以控制参数的格式,请删除周围的方括号。然后它会变得更简单。

XSLT没有数组,除非您使用XSLT 3.0和XPath 3.1支持。由于您的数据来自扩展函数,所以您必须详细展示和解释您使用的XSLT处理器、扩展函数的外观以及它是用哪种语言编写的。我们需要知道您的参数是什么数据类型。如果它是一个序列,那么您可以简单地执行
xsl:for each
,为每个值创建一个元素。如果它是一个字符串,则标记它。我正在尝试类似的方法。请编辑您的问题,并向我们展示您在做什么,无论是在XSLT方面,还是在编写扩展函数的编程语言XSLT处理器方面,您用来调用扩展函数的API。我担心
甚至不是格式良好的XML,所以我们仍然不知道您有什么类型的输入数据。太好了!哦,它在任何地方都能工作,除了IBM:(.谢谢。XSLT 1.0是如何做到的?突然,IBM给出了一个裁剪过的XSLT 2.0,奇怪的事情发生了……恐怕我不知道什么是“IBM给出了裁剪过的XSLT 2.0”意思是说。您是否使用IBM DataPower作为XSLT处理器?如果是,为什么要询问XSLT 2.0?是的,IBM DataPower.应该是2.0,但显然我错了。根据您的说明,我使用了1.0,但最后一个值没有得到这不是我的答案。IBM Data Power是XSLT 1.0处理器。但是,它支持EXSLT扩展函数如果您想在没有扩展的情况下执行此操作,请尝试以下示例: