作为我的单元测试应用程序的一部分,我检查一些日期时间字符串以获得解析的能力。我最近注意到,在一台计算机上,字符"0-02-20 11:36"
可以通过{2000-02-20 11:36:00}
解析为DateTime.TryParse(dateString, out parsedTimeStamp)
,而在其他计算机上则不能。{/ p>
string dt = "0-02-20 11:36";
DateTime parsedTimeStamp;
DateTime.TryParse(dateString, out parsedTimeStamp);
Console.WriteLine(parsedTimeStamp);
答案 0 :(得分:3)
解析DateTime
,与框架中的所有解析一样,依赖于文化。
我认为在特殊机器上,文化设置使用yyyy-MM-dd
格式,而在其他机器上,日期格式为MM-dd-yyyy
。
要解决此问题,您可以解析特定的文化或使用不变的文化。
DateTime.TryParse(dateString, CultureInfo.InvariantCulture, DateTimeStyles.None, out parsedTimeStamp);
事实证明,这些文化中有不少文化:
foreach (var c in CultureInfo.GetCultures(CultureTypes.AllCultures))
{
if (c.DateTimeFormat.ShortDatePattern == "yyyy-MM-dd")
{
Console.WriteLine("{0}: {1}", c.DisplayName, c.DateTimeFormat.ShortDatePattern);
}
}
Korean: yyyy-MM-dd
Polish: yyyy-MM-dd
Albanian: yyyy-MM-dd
Swedish: yyyy-MM-dd
Khmer: yyyy-MM-dd
Sinhala: yyyy-MM-dd
Korean (Korea): yyyy-MM-dd
Polish (Poland): yyyy-MM-dd
Albanian (Albania): yyyy-MM-dd
Swedish (Sweden): yyyy-MM-dd
Khmer (Cambodia): yyyy-MM-dd
Sinhala (Sri Lanka): yyyy-MM-dd
Sami, Northern (Sweden): yyyy-MM-dd
French (Canada): yyyy-MM-dd
Sami, Lule (Sweden): yyyy-MM-dd
Sami, Southern (Sweden): yyyy-MM-dd
Sami (Southern): yyyy-MM-dd
Sami (Lule): yyyy-MM-dd