如何通过XSLT自动增加元素/变量值



我的问题是,我想从100000开始,将Element标记"BOOKSEQNUM"的值自动递增10,请看下面,我已经放置了输入、输出(随我的XSLT一起提供)、XSLT代码和它应该提供的输出的代码。如果这在XSLT中是可能的,你能帮助我吗?我已经搜索了它的解决方案,但没有找到任何东西。

输入文件:

                <?xml version="1.0" encoding="utf-8"?>
                <r id="TYPL.HB001">
                <COMM>
                <commbody>
                <level id="comchap">
                <level id="TTPL_Z9.0002">
                <level id="TTPL_Z9.0003"/>
                </level>
                <level id="TTPL_Z9.0004.para0">
                <level id="TTPL_Z9.0005" >
                <level id="TTPL_Z9.0006"/>
                <level id="TTPL_Z9.0016"/>
                <level id="TTPL_Z9.0022"/>
                <level id="TTPL_Z9.0031">
                <level id="TTPL_Z9.0041"/>                 
                </level>
                </level>
                <level id="TTPL_Z9.0046">
                <level id="TTPL_Z9.0047"/>
                <level id="TTPL_Z9.0058"/>
                <level id="TTPL_Z9.0063">
                </level>
                </level>
                </level>
                </level>
                </commbody>
                </COMM>
                </r>

XSLT代码:

            <?xml version="1.0" encoding="UTF-8"?>
            <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
            version="2.0"> 
            <xsl:output omit-xml-declaration="yes" indent="yes"/>
            <xsl:template match="/">
            <xsl:apply-templates select="//level"/>
            </xsl:template>
            <xsl:template match="level">
            <xsl:variable name="BSN_Number">100000</xsl:variable>
            <xsl:element name="BOOKSEQNUM">
            <xsl:attribute name="id" select="./@id"/>
            <xsl:for-each select=".">
            <xsl:value-of select="$BSN_Number+10"/>
            </xsl:for-each>
            </xsl:element>       
            </xsl:template>
            </xsl:stylesheet>

即将输出:

            <BOOKSEQNUM id="comchap">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0002">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0003">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0004">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0005">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0006">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0016">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0022">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0031">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0041">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0046">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0047">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0058">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0063">100010</BOOKSEQNUM>

但我希望输出应该像:

    <BOOKSEQNUM id="comchap">100010</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0002">100020</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0003">100030</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0004">100040</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0005">100050</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0006">100060</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0016">100070</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0022">100080</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0031">100090</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0041">1000100</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0046">1000110</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0047">1000120</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0058">1000130</BOOKSEQNUM>
    <BOOKSEQNUM id="TTPL_Z9.0063">1000140</BOOKSEQNUM>
XSLT中的变量是不可变的,不能更改。然而,在这种情况下,你只需要用position()函数做一点简单的数学运算
 <xsl:value-of select="10000 + position() * 10"/>

尝试此XSLT

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="2.0"> 
    <xsl:output omit-xml-declaration="yes" indent="yes"/>
    <xsl:template match="/">
        <xsl:apply-templates select="//level"/>
    </xsl:template>
    <xsl:template match="level">
        <BOOKSEQNUM id="{@id}">
            <xsl:value-of select="10000 + position() * 10"/>
        </BOOKSEQNUM>       
    </xsl:template>
</xsl:stylesheet>

附带说明一下,不需要使用xsl:element来创建具有静态名称的元素,只需直接写出元素名称即可。还要注意在创建id属性时使用"属性值模板"。

相关内容

  • 没有找到相关文章

最新更新