使用xslt获取每月的日期

时间:2017-04-25 06:44:57

标签: xml xslt xslt-2.0

我需要使用xslt v2根据输入文件获取每个月的日期。这是我的示例数据:

<Data>
   <Field>March/02/2017/February/16/1989/December/19/2015</Field>
</Data>

我的XSLT

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xs="http://www.w3.org/2001/XMLSchema" version="2.0">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="Data">
    <xsl:copy>
        <xsl:apply-templates/>
    </xsl:copy>
</xsl:template>
<xsl:variable name="months" select="'January','February','March','April','May','June','July','August','September','October','November','December'"/>
<xsl:template match="Field">
    <xsl:variable name="Output">
        <xsl:analyze-string select="normalize-space(.)" regex="([A-Z][a-z]+)">
            <xsl:matching-substring>
                <xsl:number value="index-of($months, regex-group(1))" format="01"/>
            </xsl:matching-substring>
        </xsl:analyze-string>
    </xsl:variable>
    <Result>
        <xsl:value-of select="$Output"/>
    </Result>
</xsl:template>
</xsl:stylesheet>

生成的输出

<Data>
   <Result>030212</Result>
</Data>

生成的输出是每个月的位置,但我想在每个月之后填充日期。像这样:

<Data>
   <March>02/2017</March>
   <February>16/1989</February>
   <December>19/2015</December>
</Data>

另外,如果测试文件中的月份是大写或小写,我就会遇到问题,它没有填充输出。我

希望你能帮助我。谢谢。

1 个答案:

答案 0 :(得分:1)

我不确定我理解$monthsindex-of()的原因。看起来所有内容都已在Field

示例...

XSLT 2.0

<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output indent="yes"/>
  <xsl:strip-space elements="*"/>

  <xsl:template match="@*|node()">
    <xsl:copy>
      <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
  </xsl:template>

  <xsl:template match="Field">
    <xsl:analyze-string select="normalize-space()" regex="(\w+)/(\d{{2}}/\d{{4}})">
      <xsl:matching-substring>
        <xsl:element name="{regex-group(1)}">
          <xsl:value-of select="regex-group(2)"/>
        </xsl:element>
      </xsl:matching-substring>
    </xsl:analyze-string>
  </xsl:template>

</xsl:stylesheet>

<强>输出

<Data>
   <March>02/2017</March>
   <February>16/1989</February>
   <December>19/2015</December>
</Data>