xslt 1.0中有以下更优雅的解决方案吗?据我所知,xslt 2.0内置了函数。
我在十进制小时内输入一个数字,需要将其表示为HH:MM:SS。目前我有以下功能正常。
<xsl:variable name="decimal_hours" select="pre_lab_cost div pre_labour_rate"/>
<xsl:variable name="decimal_minutes" select="number(concat('0.',substring-after($decimal_hours, '.')))*60"/>
<xsl:variable name="decimal_seconds" select="number(concat('0.',substring-after($decimal_minutes, '.')))*60"/>
<xsl:value-of select="concat(format-number(floor($decimal_hours), '00'),
':',
format-number(floor($decimal_minutes), '00'),
':',
format-number(floor($decimal_seconds), '00')
)"/>
答案 0 :(得分:8)
这个怎么样......
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:variable name="decimal_hours" select="3.14"/>
<xsl:template match="/">
<xsl:value-of select="concat(
format-number(floor($decimal_hours ), '00:'),
format-number(floor($decimal_hours * 60 mod 60), '00:'),
format-number(floor($decimal_hours * 360 mod 360), '00'))"/>
</xsl:template>
</xsl:stylesheet>
答案 1 :(得分:0)
以防任何人遇到上述答案非常棒的问题,但我需要将小数分钟缩短为几小时:分钟:秒。 所以如果需要的话可以帮助解决这个问题,稍微削减一下......
<xsl:value-of select="concat(
format-number(floor($Decimal_Minutes div 60), '00:'),
format-number(floor($Decimal_Minutes mod 60), '00:'),
format-number(($Decimal_Minutes - floor($Decimal_Minutes)) * 60, '00'))"/>