我有一个系统,其中生成日志文件,并在每行的开头使用当前日期时间。
例如。
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
答案 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);
为了防止将来出现问题,我强烈建议您首先使用不变文化生成日志文件输出。