30042013
(2013年4月30日)のような文字列を日付形式に変換することは可能ですか?
したがって、後でformat-date
などの関数で使用できます。
fn:dateTime($arg1 as xs:date?, $arg2 as xs:time?)
は、引数を_xs:dateTime
_に変換します。
fn:substring()
および fn:concat()
を使用して、関連する部分を切り取り、_yyyy-mm-dd
_として結合してからに渡します。 _fn:dateTime
_。
Tomalakが言ったように、substring()
とconcat()
を使用して、xs:date()
としてキャストできる文字列を作成できます(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 method="text"/>
<xsl:strip-space elements="*"/>
<xsl:variable name="in" select="'30042013'"/>
<xsl:template match="/">
<xsl:variable name="date" select="xs:date(concat(
substring($in,5,4),'-',
substring($in,3,2),'-',
substring($in,1,2)))"/>
<xsl:value-of select="format-date($date,'[MNn] [D], [Y]')"/>
</xsl:template>
</xsl:stylesheet>
生成します(任意のXML入力を使用)
April 30, 2013