3

如何根据 xslt 2.0 中的时区将纪元时间转换为日期和时间?

例如,纪元时间 1212497304 转换为

GMT:2008 年 6 月 3 日星期二 12:48:24 GMT 时区:martes,2008 年 6 月 3 日 14:48:24 GMT+2

这是因为夏令时 (DST):在许多国家/地区,夏季会多出一小时,在某些日期每年都会有所不同。

例如,假设这条指令:

<xsl:value-of select=" format-dateTime(xs:dateTime('2013-07-07T23:08:00+00:00'), '[D] [MNn] [Y] [h]:[m01][PN,*-2] [Z] ([C])', 'en', 'AD', 'IST') "/>

将使用公历 (AD) 将给定的 GMT 日期事件计算为印度标准时间 (IST),但它只打印:

7 July 2013 11:08PM +00:00 (Gregorian)

所以它不会改变时区。要改变时区,我们必须使用:

adjust-dateTime-to-timezone

但是这个函数只接受以小时/分钟为单位的持续时间,而不是 TimeZone,以便处理器确定是否有 DST。

任何建议,请

4

1 回答 1

1

编辑:这并不是实际问题的答案,即如何获得正确的当地时间,尊重其时区,但我仍将其留在这里,因为它可能对某人有用。

因为纪元距离 unix 时间只有几秒钟,所以您可以像这样将它添加到 unix 时间:

Unix 时间是自 1970-01-01 午夜以来经过的秒数,您可以这样做:

<xsl:value-of select="xs:dateTime('1970-01-01T00:00:00') + xs:dayTimeDuration('PT1212497304S')"
    />

这将为您提供正确的 xs:dateTime 2008-06-03T12:48:24

放入一个函数:

<xsl:function name="fn:epochToDate">
    <xsl:param name="epoch"/>
    <xsl:variable name="dayTimeDuration" select="concat('PT',$epoch,'S')"/>
    <xsl:value-of select="xs:dateTime('1970-01-01T00:00:00') + xs:dayTimeDuration($dayTimeDuration)"/>
</xsl:function>
于 2014-03-03T09:33:12.727 回答