2012-08-17 64 views
28

我正在解析ASP.NET WebForms页面中的日期时间值,并且日期字符串一直被DateTime.TryParseExact()方法拒绝,即使它明确地匹配提供的格式字符串之一。DateTime.TryParseExact()拒绝有效格式

这似乎是我的机器上不能在家里,但在生产服务器上的工作,所以我参与思维的本地日期设置,但即使我提供一个IFormatProvider (CultureInfo)对象作为参数

出现此错误下面的代码:

DateTime startDate; 
string[] formats = { "dd/MM/yyyy", "dd/M/yyyy", "d/M/yyyy", "d/MM/yyyy", 
        "dd/MM/yy", "dd/M/yy", "d/M/yy", "d/MM/yy"}; 

var errStart = row.FindControl("errStartDate"); //my date format error message 
if (!DateTime.TryParseExact(txtStartDate.Text, formats, null, DateTimeStyles.None, out startDate)) 
{ 
    errStart.Visible = true; //we get here even with a string like "20/08/2012" 
    return false; 
} 
else 
{ 
    errStart.Visible = false; 
} 

注意我给上面一个null FormatProvider出现同样的问题,当我提供CultureInfo对象 (CultureInfo provider = new CultureInfo("en-US"))此参数。

我错过了什么?

+2

在美国文化中,日期格式为M/d/Y不是D/M/Y – StuartLC 2012-08-17 04:50:27

+1

即使不提FormatProvider,该代码似乎工作正常为了我。尝试指定InvariantCulture。 – danish 2012-08-17 04:51:00

回答

39

尝试:

DateTime.TryParseExact(txtStartDate.Text, formats, 
     System.Globalization.CultureInfo.InvariantCulture, 
     System.Globalization.DateTimeStyles.None, out startDate) 
5

这是一个简单的方法,使用ParseExact

CultureInfo provider = CultureInfo.InvariantCulture; 
DateTime result; 
dateString = "Sun 08 Jun 2013 8:30 AM -06:00"; 
format = "ddd dd MMM yyyy h:mm tt zzz"; 
result = DateTime.ParseExact(dateString, format, provider); 

这应该为你工作。

6

在这里你可以检查几件事情。

  1. 正确使用的日期格式。您可以为DateTime.TryParseExact提供多种格式。检查完整的格式列表,可用here
  2. CultureInfo.InvariantCulture这更有可能增加问题。因此,不要将NULL设置为CultureInfo provider = new CultureInfo("en-US"),您可以将其写入。 。

    if (!DateTime.TryParseExact(txtStartDate.Text, formats, 
           System.Globalization.CultureInfo.InvariantCulture, 
           System.Globalization.DateTimeStyles.None, out startDate)) 
    { 
        //your condition fail code goes here 
        return false; 
    } 
    else 
    { 
        //success code 
    }