Access导出的XSL转换

时间:2015-05-26 08:08:01

标签: xml ms-access xslt export

我试图为日期进行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

请帮我解决这个转变。

1 个答案:

答案 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>