C# · 12月 29, 2021

c# – DateTime.TryParseExact无法正常工作

任何人都可以解释为什么以下代码段返回true?

根据The “d” custom format specifier的文档,“单位数字的日期格式化没有前导零”.那么为什么TryParseExact不会失败,当我给它一个单位数的前一个零的一天?

DateTime x;return DateTime.TryParseExact( “01/01/2001″,@”d\/MM\/yyyy”,null,System.Globalization.DateTimeStyles.None,out x);

UPDATE

我想也许我原来不清楚我真正想要得到的是:为什么TryParseExact接受一些不完全匹配的值?从我所看到的所有文档中,’01’和’1’匹配的错误与’MM’匹配’March’以及’03’一样多.这里的问题并不在于值是等价的,它们与格式不符.

相关的文档片段有:

>从TryParseExact:字符串表示形式必须与指定的格式完全一致.
>从The ‘d’ Specifier:单位数字的日期格式化没有前导零.

对我来说,’01’有一个前导0,因此并不完全符合’d’

解决方法 从DateTimeParse.ParseByFormat()中的.NET 4源: case ‘d’: // Day & Day of week tokenLen = format.GetRepeatCount(); if (tokenLen <= 2) { // “d” & “dd” if (!ParseDigits(ref str,tokenLen,out tempDay)) { if (!parseInfo.fCustomNumberParser || !parseInfo.parseNumberDelegate(ref str,out tempDay)) { result.SetFailure(ParseFailureKind.Format,”Format_BadDateTime”,null); return (false); } } if (!CheckNewValue(ref result.Day,tempDay,ch,ref result)) { return (false); } } else {…}

解析器将“d”和“dd”结合在一起.