-1

我的 XSLT 中有一个下面的循环,它为我提供了来自输入 XMLfor-each的不同值的连接字符串CUST_PO_NUMBER

<xsl:key name="custpo"
         match="LIST_G_DELV/G_DELV/LIST_G_INV_LINES/G_INV_LINES"
         use="CUST_PO_NUMBER"/>
<xsl:template match="XXFIN_GBL_RAINV_PRINT">
    <xsl:apply-templates select="LIST_G_INV"/>
</xsl:template>
<xsl:template match="LIST_G_INV">
    <xsl:for-each select="G_INV">
        <xsl:value-of select="CUSTOMER_TRX_ID"/>
        <xsl:text>|</xsl:text>
        <xsl:value-of select="substring(LIST_G_SEB/G_SEB/SEB_NAME,1,255)"/>
        <xsl:text>|</xsl:text>
        <xsl:value-of select="substring(IDM_BILL_TO_CUSTOMER_NAME,1,255)"/>
        <xsl:text>|</xsl:text>
        <xsl:value-of select="BILL_TO_CUSTOMER_NUMBER"/>
        <xsl:text>|</xsl:text>
        <xsl:value-of select="TRX_NUMBER"/>
        <xsl:text>|</xsl:text>
        <xsl:for-each select="LIST_G_DELV/G_DELV/LIST_G_INV_LINES/G_INV_LINES[generate-id()=generate-id(key('custpo',CUST_PO_NUMBER)[1])]">
            <xsl:value-of select="CUST_PO_NUMBER"/>
            <xsl:if test="not(position() = last())">
                <xsl:text>;</xsl:text>
            </xsl:if>
        </xsl:for-each>
        <xsl:text>|</xsl:text>
        <xsl:value-of select="CUST_ISO_LANGUAGE"/>
    </xsl:for-each>
</xsl:template>

此 XSLT 的最终输出是 CSV 文件(由管道 | 分隔)。我们可以将 CUST_PO_NUMBER 元素上的 for-each 循环的结果截断为 1000 个字符吗?

4

1 回答 1

0

我相信如果您替换以下内容,这应该会起作用for-each

<xsl:for-each select="LIST_G_DELV/G_DELV/LIST_G_INV_LINES/G_INV_LINES[generate-id()=generate-id(key('custpo',CUST_PO_NUMBER)[1])]">
        <xsl:value-of select="CUST_PO_NUMBER"/>
        <xsl:if test="not(position() = last())">
            <xsl:text>;</xsl:text>
        </xsl:if>
</xsl:for-each>

和:

 <xsl:variable name="values">
    <xsl:for-each select="LIST_G_DELV/G_DELV/LIST_G_INV_LINES/G_INV_LINES[generate-id()=generate-id(key('custpo',CUST_PO_NUMBER)[1])]">
        <xsl:value-of select="CUST_PO_NUMBER"/>
        <xsl:if test="not(position() = last())">
            <xsl:text>;</xsl:text>
        </xsl:if>
    </xsl:for-each>
 </xsl:variable>
 <xsl:value-of select="substring($values, 1, 1000)" />

并且由于您substring()无论如何都会使用 a ,因此您可以通过执行以下操作消除ifand text

 <xsl:variable name="values">
    <xsl:for-each select="LIST_G_DELV/G_DELV/LIST_G_INV_LINES/G_INV_LINES[generate-id()=generate-id(key('custpo',CUST_PO_NUMBER)[1])]">
        <xsl:value-of select="concat(';', CUST_PO_NUMBER)"/>
    </xsl:for-each>
 </xsl:variable>
 <xsl:value-of select="substring($values, 2, 1001)" />
于 2013-01-23T12:18:29.710 回答