固定长度的填充值 - xslt
Pad Value with fix length - xslt
我有这个简单的 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> </xsl:text>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
Meter Number 参数最多可以包含 10 个字母数字。例如,如果值为 232345,我想显示(用空格填充):'232345'。我对 Import Active kWh 有相同的情况,这是一个数字字段修复 12 类型数字,但如果值为 56884,我想显示(在开头填充 0)'000000056884'。
感谢您一如既往的有用帮助!
此致。
XSLT 具有 format-number
功能,因此 format-number(translate(Col[@name = 'Import Active kWh']/.,',','.'), '000000000000')
应该可以解决一个问题。
对于数字字段,您可以简单地使用 format-number()
函数,例如:
<xsl:value-of select="format-number($numeric-field, '000000000000')"/>
对于字母数字字段,尝试:
<xsl:value-of select="substring(concat(' ', $alphanumeric-field), 1 + string-length($alphanumeric-field))" />
如果您需要多次执行此操作,请考虑将其重写为一个函数。
注意:此位置步骤 /.
不执行任何操作。
我有这个简单的 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> </xsl:text>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
Meter Number 参数最多可以包含 10 个字母数字。例如,如果值为 232345,我想显示(用空格填充):'232345'。我对 Import Active kWh 有相同的情况,这是一个数字字段修复 12 类型数字,但如果值为 56884,我想显示(在开头填充 0)'000000056884'。
感谢您一如既往的有用帮助!
此致。
XSLT 具有 format-number
功能,因此 format-number(translate(Col[@name = 'Import Active kWh']/.,',','.'), '000000000000')
应该可以解决一个问题。
对于数字字段,您可以简单地使用 format-number()
函数,例如:
<xsl:value-of select="format-number($numeric-field, '000000000000')"/>
对于字母数字字段,尝试:
<xsl:value-of select="substring(concat(' ', $alphanumeric-field), 1 + string-length($alphanumeric-field))" />
如果您需要多次执行此操作,请考虑将其重写为一个函数。
注意:此位置步骤 /.
不执行任何操作。