如何转换xsl dateformat?

时间:2012-01-30 09:00:38

标签: xslt date-format

如何转换

  

01/29/2012 00:00

  

2012年1月29日,星期一

在xslt?

3 个答案:

答案 0 :(得分:3)

<强>予。 XSLT 1.0解决方案(不生成星期几),比其他答案更简单,更短

<xsl:stylesheet version="1.0"
 xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
 xmlns:my="my:my">  
 <xsl:output method="text"/>

 <my:months>
  <m>Jan</m><m>Feb</m><m>Mar</m><m>Apr</m><m>May</m><m>Jun</m>
  <m>Jul</m><m>Aug</m><m>Sep</m><m>Oct</m><m>Nov</m><m>Dec</m>
 </my:months>

 <xsl:variable name="vMonthNames" select=
 "document('')/*/my:months/*"/>

 <xsl:template match="text()">
     <xsl:variable name="vnumMonth" select="substring-before(., '/')"/>

     <xsl:variable name="vDay" select=
     "substring-before(substring-after(., '/'), '/')"/>

     <xsl:variable name="vYear" select=
     "substring-before(substring-after(substring-after(., '/'), '/'), ' ')"/>

     <xsl:value-of select=
      "concat($vMonthNames[0+$vnumMonth], ' ',
              $vDay, ', ',
              $vYear
              )"/>
 </xsl:template>
</xsl:stylesheet>

对以下XML文档应用此转换时:

<t>01/29/2012 00:00</t>

生成了想要的结果

Jan 29, 2012

II。在XSLT 2.0中,可以使用非常强大的日期时间函数,例如format-dateTime()

<xsl:stylesheet version="2.0"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:xs="http://www.w3.org/2001/XMLSchema">
    <xsl:output omit-xml-declaration="yes" indent="yes"/>

 <xsl:template match="text()">
     <xsl:variable name="vComps" select=
      "tokenize(., '/')"/>

    <xsl:variable name="vstdDate" select=
     "concat(substring-before($vComps[3], ' '), '-',
             $vComps[1], '-',
             $vComps[2]
          )"/>

  <xsl:sequence select=
      "format-date(xs:date($vstdDate), '[FNn], [MNn] [D], [Y]')"/>
 </xsl:template>
</xsl:stylesheet>

当在同一个XML文档(上面)上应用此转换时,会生成所需的正确结果

Sunday, January 29, 2012

答案 1 :(得分:1)

来源:http://geekswithblogs.net/workdog/archive/2007/02/08/105858.aspx#110623

“我已修改为将”2007年1月20日下午10:22:28“转换为”2007年1月20日“...以保存发现有用的人几分钟。

<xsl:template name="FormatDate">
<!-- expected date format 1/20/2007 10:22:28 PM [OR] 01/20/2007 10:22:28 PM -->
<xsl:param name="DateTime" />
<!-- new date format January 20, 2007 -->
<xsl:variable name="mo">
<xsl:value-of select="substring-before($DateTime,'/')" />
</xsl:variable>
<xsl:variable name="day-temp">
<xsl:value-of select="substring-after($DateTime,'/')" />
</xsl:variable>
<xsl:variable name="day">
<xsl:value-of select="substring-before($day-temp,'/')" />
</xsl:variable>
<xsl:variable name="year-temp">
<xsl:value-of select="substring-after($day-temp,'/')" />
</xsl:variable>
<xsl:variable name="year">
<xsl:value-of select="substring($year-temp,1,4)" />
</xsl:variable>

<xsl:choose>
<xsl:when test="$mo = '1' or $mo = '01'">January</xsl:when>
<xsl:when test="$mo = '2' or $mo = '02'">February</xsl:when>
<xsl:when test="$mo = '3' or $mo = '03'">March</xsl:when>
<xsl:when test="$mo = '4' or $mo = '04'">April</xsl:when>
<xsl:when test="$mo = '5' or $mo = '05'">May</xsl:when>
<xsl:when test="$mo = '6' or $mo = '06'">June</xsl:when>
<xsl:when test="$mo = '7' or $mo = '07'">July</xsl:when>
<xsl:when test="$mo = '8' or $mo = '08'">August</xsl:when>
<xsl:when test="$mo = '9' or $mo = '09'">September</xsl:when>
<xsl:when test="$mo = '10'">October</xsl:when>
<xsl:when test="$mo = '11'">November</xsl:when>
<xsl:when test="$mo = '12'">December</xsl:when>
</xsl:choose>
<xsl:value-of select="' '"/>
<xsl:if test="(string-length($day) &lt; 2)">
<xsl:value-of select="0"/>
</xsl:if>
<xsl:value-of select="$day"/>
<xsl:value-of select="', '"/>
<xsl:value-of select="$year"/>
</xsl:template> 

答案 2 :(得分:0)

为这个非常复杂的解决方案道歉,但它会在XSLT 1.0中为您提供您想要的内容:

<xsl:variable name="months" select="'JanFebMarAprMayJunJulAugSepOctDec'" />
<xsl:variable name="weekdays"  select="'Monday   Tuesday  WednesdayThursday Friday   Saturday Sunday   '" />

<xsl:template match="date">
  <xsl:variable name="days">
    <xsl:value-of select="
      ((substring(.,7,4) - 1970) * 365)+floor((substring(.,7,4) - 1970) div 4)+
      substring('000,031,059,090,120,151,181,212,243,273,304,334,365',substring(.,1,2)*4-3,3)+
      (substring(.,4,2)-1)+
      (1-floor(((substring(.,7,4) mod 4) + 2) div 3))*floor((substring(.,1,2)+17) div 20)
    " />
  </xsl:variable>

  <xsl:value-of select="concat(
    normalize-space(substring($weekdays,(($days+3) mod 7) * 9 + 1, 9)),
    ', ',
    substring($months,substring(.,1,2) * 3 - 2, 3),
    ' ',
    substring(.,4,2) + 0,
    ', ',
    substring(.,7,4)
   )" />
</xsl:template>

变量'days'的构造使用了一个相当复杂的公式来确定自1970年1月1日以来的天数。这是一个简单的事情,从那里添加3(因为1970年1月1日是星期四)并采用此图的mod 7从weekdays变量substr得到星期几。

如果您打算使用日期很多,请获取XSLT2!