我正在获取带有日期值的输入xml,如下所示。
<date-data>
<name>selectedDate</name>
<value>2013-10-21 8:03</value>
</date-data>
<date-data>
<name>selectedDate</name>
<value>2013-10-24 9:03</value>
</date-data>
我正在尝试将日期格式转换为YYYY-DD-MM HH:MM并期望日期字段的输出为
2013-10-21 08:03
2013-10-24 09:03
我正在使用xsl,如下所示
<xsl:variable name="dt" as="xs:dateTime" select="value"/>
<xsl:value-of select="{format-dateTime($dt, '[Y0001]-[M01]-[D01]T[H01]:[m01]')}" />
我收到此日期格式字符串的错误。任何帮助都非常感谢。
答案 0 :(得分:2)
您需要提取日期格式的部分以构建xs:dateTime
值,然后才能使用format-dateTime
。这是一个示例:
<xsl:stylesheet
version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:mf="http://example.com/mf"
exclude-result-prefixes="xs mf">
<xsl:output method="xml" indent="yes"/>
<xsl:function name="mf:pad" as="xs:string">
<xsl:param name="value" as="xs:string"/>
<xsl:param name="length" as="xs:integer"/>
<xsl:variable name="zeros" as="xs:string" select="'0000000000'"/>
<xsl:sequence select="concat(substring($zeros, 1, $length - string-length($value)), $value)"/>
</xsl:function>
<xsl:template match="date-data">
<xsl:variable name="dt" as="xs:dateTime">
<xsl:analyze-string select="value" regex="([0-9]{{4}})-([0-9]{{1,2}})-([0-9]{{1,2}}) ([0-9]{{1,2}}):([0-9]{{1,2}})">
<xsl:matching-substring>
<xsl:sequence select="xs:dateTime(concat(regex-group(1), '-',
mf:pad(regex-group(2), 2), '-',
mf:pad(regex-group(3), 2), 'T',
mf:pad(regex-group(4), 2), ':',
mf:pad(regex-group(5), 2),
':00'))"/>
</xsl:matching-substring>
</xsl:analyze-string>
</xsl:variable>
<xsl:value-of select="format-dateTime($dt, '[Y0001]-[M01]-[D01]T[H01]:[m01]')" />
</xsl:template>
</xsl:stylesheet>
您可能需要根据格式的变化来调整代码。