任何人都可以解释为什么以下代码段返回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”结合在一起.