我试图为日期进行xsl转换。我可以为一个日期专栏进行转换,而不是所有人。
我需要转换所有日期时间,以便在没有时间的情况下格式化yyyy-mm-dd或其他格式。
这是我的XML
<dataroot xmlns:od="urn:schemas-microsoft-com:officedata">
<VYKRESY_TABULKA>
<NAZEV>OBJIMKA DIL 2</NAZEV>
<FORMAT>3</FORMAT>
<CISLO_VYKRESU>E1388</CISLO_VYKRESU>
<TYP_STROJE>W3651</TYP_STROJE>
<SERIE>2014-06-19T00:00:00</SERIE>
<K1>2014-06-19T00:00:00</K1>
<K3>2014-06-19T00:00:00</K3>
<K46>2014-06-19T00:00:00</K46>
<RIZENA_DOKUMENTACE>R</RIZENA_DOKUMENTACE>
<DRUH>D</DRUH>
</VYKRESY_TABULKA>
</dataroot>
此代码可以工作,但只适用于一列,我不知道如何一起制作它。我不知道该怎么做。
<xsl:template match="*">
<xsl:param name="parentElm">
<xsl:value-of select="name(..)" />
</xsl:param>
<xsl:choose>
<xsl:when test="local-name() = 'SERIE'">
<xsl:element name="SERIE">
<xsl:call-template name="FormatDate">
<xsl:with-param name="DateTime" select="."/>
</xsl:call-template>
</xsl:element>
</xsl:when>
<xsl:otherwise>
<xsl:element name="{local-name()}">
<xsl:copy-of select="@*" />
<xsl:apply-templates select="@* | node()" />
</xsl:element>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
<xsl:template name="FormatDate">
<xsl:param name="DateTime" />
<xsl:variable name="date">
<xsl:value-of select="substring-before($DateTime,'T')" />
</xsl:variable>
<xsl:if test="string-length($date) != 10">
<xsl:value-of select="$DateTime"/>
</xsl:if>
<xsl:if test="string-length($date) = 10">
<xsl:value-of select="$date"/>
</xsl:if>
</xsl:template>
我发现这个网络芽不起作用,因为列没有标记为datetime。 https://msdn.microsoft.com/en-us/library/ms256099%28v=vs.110%29.aspx
请帮我解决这个转变。
答案 0 :(得分:0)
简单地说:
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<!-- identity transform -->
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="SERIE | K1 | K3 | K46">
<xsl:copy>
<xsl:value-of select="substring-before(.,'T')" />
</xsl:copy>
</xsl:template>
</xsl:stylesheet>