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

前端之家收集整理的这篇文章主要介绍了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”结合在一起.

猜你在找的C#相关文章