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, tokenLen, 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”结合在一起.

相关文章
相关标签/搜索