DateTime.ToString格式化并将结果字符串反转回日期时间

时间:2015-11-19 16:01:09

标签: c# .net parsing datetime culture

我有一个系统,其中生成日志文件,并在每行的开头使用当前日期时间。

例如。

LogUtil.Logger(DateTime.ToString("yyyy/MM/dd") + "|" + "My Message Here");

根据文化,此日志文件可能会在年,月和日之间产生不同的分隔符。

例如。

2015/11/19  or  2015.11.19

我正在编写一个单独的实用程序,它将获取此结果日志文件并对其进行解析,并将其他信息发送给第三方。

由于日期格式不同,我怎样才能让它每次都正确解析它。

目前正在使用:

DateTime.TryParseExact(line.Substring(0, 10), "yyyy/MM/dd", CultureInfo.InvariantCulture, DateTimeStyles.None, out Date);

此格式说明符仅正确格式化2015/11/19

2 个答案:

答案 0 :(得分:2)

您可以将多种格式传递给DateTime.TryParseExact。使用overload

DateTime.TryParseExact(line.Substring(0, 10), 
                    new[] {"yyyy/MM/dd", "yyyy.MM.dd"}, 
                    CultureInfo.InvariantCulture, 
                    DateTimeStyles.None, 
                    out Date);

这适用于两种格式:2015/11/19 or 2015.11.19

答案 1 :(得分:0)

如果您可以确定使用哪种文化来生成给定的日志文件,请使用该文化而不是InvariantCulture。

var culture = CultureInfo.GetCultureInfoByIetfLanguageTag("tr-TR"); // e.g.
DateTime.TryParseExact(line.Substring(0, 10), 
                "yyyy/MM/dd", 
                culture, 
                DateTimeStyles.None, 
                out Date);

为了防止将来出现问题,我强烈建议您首先使用不变文化生成日志文件输出。