具有固定长度的填充值 - xslt

时间:2015-08-04 09:30:49

标签: xslt spaces pad

我有这个简单的xslt代码:

<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
   <xsl:output method="text" indent="yes"/>
   <xsl:template match="/racine/Requete">
        <xsl:for-each select="Row">
            <xsl:value-of select="Col[@name = 'Service Point']/." />
            <xsl:text>ME02</xsl:text>
            <xsl:value-of select="Col[@name = 'Meter Number']/." />
            <xsl:value-of select="Col[@name = 'Date']/." />
            <xsl:value-of select="translate(Col[@name = 'Import Active kWh']/.,',','.')" />
            <xsl:text>30000000000000000000</xsl:text>
            <xsl:text>&#13;</xsl:text>
        </xsl:for-each>
    </xsl:template>
</xsl:stylesheet>

Meter Number参数最多可包含10个字母数字。所以,如果值为232345,我想显示(用空格填充):&#39; 232345&#39 ;.我对Import Active kWh有相同的情况,这是一个数字字段修复12类型数字,但如果值为56884,我想显示(在开头填0)&00; 000000056884&#39;。

感谢您照常提供的有用帮助!

问候。

2 个答案:

答案 0 :(得分:3)

对于数字字段,您只需使用format-number()函数,例如:

<xsl:value-of select="format-number($numeric-field, '000000000000')"/>

对于字母数字字段,请尝试:

<xsl:value-of select="substring(concat('          ', $alphanumeric-field), 1 + string-length($alphanumeric-field))" />

如果您需要多次执行此操作,请考虑将其重新编写为函数。

注意:此位置步骤/.不执行任何操作。

答案 1 :(得分:0)

XSLT具有format-number功能,因此format-number(translate(Col[@name = 'Import Active kWh']/.,',','.'), '000000000000')应解决一个问题。