我的XML:
<root>
<Name>Test</Name>
<DOB>10-11-1989</DOB>
<root>
我需要使用XSLT获取当前时间日期格式(毫秒)。 我使用的是 XSLT版本1.0。。
在Trasformation之后,我的XML应如下所示:
<root>
<Name>Test</Name>
<DOB>10-11-1989</DOB>
<currentDate>2014-05-21-01.25.32.000000</currentDate>
<root>
我找到了2.0版的解决方案,但这对我没有帮助。
答案 0 :(得分:1)
仅XSLT 1.0无法提供获取当前日期或时间的任何方法。
如果您的处理器支持它,您可以使用日期时间()EXSLT扩展功能 - 但是,我不认为这将包括毫秒。
或者,您可以在运行时将时间戳作为参数传递给样式表。
答案 1 :(得分:0)
这是一个使用Java的示例,它与Xalan一起使用,并且在ORACLE JRE中是默认的。
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:java="http://xml.apache.org/xslt/java"
exclude-result-prefixes="java">
<xsl:output indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="/root">
<xsl:copy>
<xsl:copy-of select="@*|node()"/>
<dateTimeStamp>
<xsl:value-of select="java:format(java:java.text.SimpleDateFormat.new('yyyy-MM-dd-HH.mm.ss.SSSSSS a'), java:java.util.Date.new())" />
</dateTimeStamp>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
来自http://www.heber.it/?p=1053。
如果您想要12小时格式,只需更改
即可<xsl:value-of select="java:format(java:java.text.SimpleDateFormat.new('yyyy-MM-dd-HH.mm.ss.SSSSSS'), java:java.util.Date.new())" />
到
<xsl:value-of select="java:format(java:java.text.SimpleDateFormat.new('yyyy-MM-dd-hh.mm.ss.SSSSSS a'), java:java.util.Date.new())" />
输出:
<root>
<Test>tested</Test>
<dateTimeStamp>2014-05-23-01.57.04.000441 PM</dateTimeStamp>
</root>