加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-15 06:57:06 所属栏目:百科 来源:网络整理
导读:任何人都可以解释为什么以下代码段返回true? 根据The “d” custom format specifier的文档,“单位数字的日期格式化没有前导零”.那么为什么TryParseExact不会失败,当我给它一个单位数的前一个零的一天? DateTime x;return DateTime.TryParseExact( "01/01
任何人都可以解释为什么以下代码段返回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”结合在一起.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读