2

这是一个极端情况。

我正在研究将无效的本地时间转换为 UTC 的修复程序。在本地时区中,由于夏令时 (dst),某些时间段无法转换为 UTC。给定正确的时区,TimeZone.IsInvalidTime() 可用于识别此类数据时间值。

在埃及,2010 年 DST 每年更改 4 次(由于斋月)。IsInvalidTime() 似乎没有检测到第二次这样的转换。

编辑 TimeZoneInfo.ConvertTime(),这是我用来实际将其转换为 UTC 的,将这些值转换为 UTC。一个错误的转换,但转换都是一样的。

有人遇到过这个,有什么建议可以覆盖这个吗?

4

1 回答 1

2

Windows 时区数据库在准确反映时区规则的历史变化方面是出了名的糟糕。请改用 IANA/Olson 时区数据库。有关不同数据库的更多信息,请参阅TimeZone 标签 wiki

对于 .Net,最好的解决方案是使用NodaTime。它完全实现了 IANA/Olson 数据库。您将使用Africa/Cairo准确反映所有历史变化的时区。

于 2013-04-23T16:52:24.507 回答