我正在解析ASP.NET WebForms
页面中的 DateTime 值,并且日期字符串不断被 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"))
此参数。
我错过了什么?
尝试:
DateTime.TryParseExact(txtStartDate.Text, formats,
System.Globalization.CultureInfo.InvariantCulture,
System.Globalization.DateTimeStyles.None, out startDate)
在这里你可以检查几件事。
- 正确使用的日期格式。您可以为
DateTime.TryParseExact
提供多种格式。查看此处提供的完整格式列表。 -
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 }
这是简单方法,使用 ParseExact
CultureInfo provider = CultureInfo.InvariantCulture;
DateTime result;
String dateString = "Sun 08 Jun 2013 8:30 AM -06:00";
String format = "ddd dd MMM yyyy h:mm tt zzz";
result = DateTime.ParseExact(dateString, format, provider);
这应该适合您。
尝试 C# 7.0
var Dob= DateTime.TryParseExact(s: YourDateString,format: "yyyyMMdd",provider: null,style: 0,out var dt)
? dt : DateTime.Parse("1800-01-01");
string DemoLimit = "02/28/2018";
string pattern = "MM/dd/yyyy";
CultureInfo enUS = new CultureInfo("en-US");
DateTime.TryParseExact(DemoLimit, pattern, enUS,
DateTimeStyles.AdjustToUniversal, out datelimit);
有关 https://msdn.microsoft.com/en-us/library/ms131044(v=vs.110)的更多信息.aspx