FormatException未被用户代码datetime处理
本文关键字:datetime 处理 代码 用户 FormatException | 更新日期: 2023-09-27 18:04:52
当我尝试从文本框中获取日期值时,值为:"05/22/2014"
我想把它插入到我的数据库字段,有一个日期时间格式,所以我想首先转换它。所以我使用Convert.ToDateTime
函数从文本框的文本属性的值。但是我得到了一个错误,说
FormatException
未被用户代码处理。弦不是可识别为有效的日期时间
是不是我在做什么,当我使用Convert.ToDateTime
上的文本框文本值?
<asp:TextBox ID="cldStartProj" CssClass="datePicker" TextMode="DateTime" runat="server"></asp:TextBox>
DateTime dtDateStart = Convert.ToDateTime(cldStartProj.Text);
Convert.ToDateTime(string)
默认使用CurrentCulture
。
public static DateTime ToDateTime(String value)
{
if (value == null)
return new DateTime(0);
return DateTime.Parse(value, CultureInfo.CurrentCulture);
}
可能,您的CurrentCulture
没有MM/dd/yyyy
格式作为标准日期和时间。这就是为什么你的Convert.ToDateTime
会失败。您可以使用GetAllDateTimePatterns
方法查看所有标准日期和时间模式。
下面是一个关于LINQPad的例子;
CultureInfo.CurrentCulture.DateTimeFormat.GetAllDateTimePatterns().Dump();
您可以使用DateTime.TryParseExact
或DateTime.ParseExact
方法解析自定义日期和时间字符串。
string s = "05/22/2014";
DateTime dt;
if(DateTime.TryParseExact(s, "MM/dd/yyyy", CultureInfo.CurrentCulture,
DateTimeStyles.None, out dt))
{
// parsing successful
}
else
{
// not successful
}
但是请记住,/ Custom Format Specifier
在自定义日期和格式字符串中具有特殊含义。这意味着像用当前区域性日期分隔符替换me。这意味着,即使您的字符串具有完全相同的格式,如果您的DateSeparator
属性不是/
,您的解析操作将失败。
属性为'en-ca'
正如我所说,您的文化没有MM/dd/yyyy
的标准格式。这里是您的en-ca
区域性支持的标准格式的完整列表;
foreach(var format in CultureInfo.GetCultureInfo("en-ca").DateTimeFormat.GetAllDateTimePatterns())
{
Console.WriteLine(format);
}
输出将是;
dd/MM/yyyy
dd/MM/yy
d/M/yy
yyyy-MM-dd
yy-MM-dd
M/dd/yy
dd-MMM-yy
dd-MMM-yyyy
MMMM-dd-yy
MMMM d, yyyy
d-MMM-yy
dddd, MMMM dd, yyyy
MMMM-dd-yy h:mm tt
MMMM-dd-yy hh:mm tt
MMMM-dd-yy HH:mm
MMMM-dd-yy H:mm
MMMM d, yyyy h:mm tt
MMMM d, yyyy hh:mm tt
MMMM d, yyyy HH:mm
MMMM d, yyyy H:mm
d-MMM-yy h:mm tt
d-MMM-yy hh:mm tt
d-MMM-yy HH:mm
d-MMM-yy H:mm
dddd, MMMM dd, yyyy h:mm tt
dddd, MMMM dd, yyyy hh:mm tt
dddd, MMMM dd, yyyy HH:mm
dddd, MMMM dd, yyyy H:mm
MMMM-dd-yy h:mm:ss tt
MMMM-dd-yy hh:mm:ss tt
MMMM-dd-yy HH:mm:ss
MMMM-dd-yy H:mm:ss
MMMM d, yyyy h:mm:ss tt
MMMM d, yyyy hh:mm:ss tt
MMMM d, yyyy HH:mm:ss
MMMM d, yyyy H:mm:ss
d-MMM-yy h:mm:ss tt
d-MMM-yy hh:mm:ss tt
d-MMM-yy HH:mm:ss
d-MMM-yy H:mm:ss
dddd, MMMM dd, yyyy h:mm:ss tt
dddd, MMMM dd, yyyy hh:mm:ss tt
dddd, MMMM dd, yyyy HH:mm:ss
dddd, MMMM dd, yyyy H:mm:ss
dd/MM/yyyy h:mm tt
dd/MM/yyyy hh:mm tt
dd/MM/yyyy HH:mm
dd/MM/yyyy H:mm
dd/MM/yy h:mm tt
dd/MM/yy hh:mm tt
dd/MM/yy HH:mm
dd/MM/yy H:mm
d/M/yy h:mm tt
d/M/yy hh:mm tt
d/M/yy HH:mm
d/M/yy H:mm
yyyy-MM-dd h:mm tt
yyyy-MM-dd hh:mm tt
yyyy-MM-dd HH:mm
yyyy-MM-dd H:mm
yy-MM-dd h:mm tt
yy-MM-dd hh:mm tt
yy-MM-dd HH:mm
yy-MM-dd H:mm
M/dd/yy h:mm tt
M/dd/yy hh:mm tt
M/dd/yy HH:mm
M/dd/yy H:mm
dd-MMM-yy h:mm tt
dd-MMM-yy hh:mm tt
dd-MMM-yy HH:mm
dd-MMM-yy H:mm
dd-MMM-yyyy h:mm tt
dd-MMM-yyyy hh:mm tt
dd-MMM-yyyy HH:mm
dd-MMM-yyyy H:mm
dd/MM/yyyy h:mm:ss tt
dd/MM/yyyy hh:mm:ss tt
dd/MM/yyyy HH:mm:ss
dd/MM/yyyy H:mm:ss
dd/MM/yy h:mm:ss tt
dd/MM/yy hh:mm:ss tt
dd/MM/yy HH:mm:ss
dd/MM/yy H:mm:ss
d/M/yy h:mm:ss tt
d/M/yy hh:mm:ss tt
d/M/yy HH:mm:ss
d/M/yy H:mm:ss
yyyy-MM-dd h:mm:ss tt
yyyy-MM-dd hh:mm:ss tt
yyyy-MM-dd HH:mm:ss
yyyy-MM-dd H:mm:ss
yy-MM-dd h:mm:ss tt
yy-MM-dd hh:mm:ss tt
yy-MM-dd HH:mm:ss
yy-MM-dd H:mm:ss
M/dd/yy h:mm:ss tt
M/dd/yy hh:mm:ss tt
M/dd/yy HH:mm:ss
M/dd/yy H:mm:ss
dd-MMM-yy h:mm:ss tt
dd-MMM-yy hh:mm:ss tt
dd-MMM-yy HH:mm:ss
dd-MMM-yy H:mm:ss
dd-MMM-yyyy h:mm:ss tt
dd-MMM-yyyy hh:mm:ss tt
dd-MMM-yyyy HH:mm:ss
dd-MMM-yyyy H:mm:ss
MMMM dd
MMMM dd
yyyy'-'MM'-'dd'T'HH':'mm':'ss.fffffffK
yyyy'-'MM'-'dd'T'HH':'mm':'ss.fffffffK
ddd, dd MMM yyyy HH':'mm':'ss 'GMT'
ddd, dd MMM yyyy HH':'mm':'ss 'GMT'
yyyy'-'MM'-'dd'T'HH':'mm':'ss
h:mm tt
hh:mm tt
HH:mm
H:mm
h:mm:ss tt
hh:mm:ss tt
HH:mm:ss
H:mm:ss
yyyy'-'MM'-'dd HH':'mm':'ss'Z'
MMMM-dd-yy h:mm:ss tt
MMMM-dd-yy hh:mm:ss tt
MMMM-dd-yy HH:mm:ss
MMMM-dd-yy H:mm:ss
MMMM d, yyyy h:mm:ss tt
MMMM d, yyyy hh:mm:ss tt
MMMM d, yyyy HH:mm:ss
MMMM d, yyyy H:mm:ss
d-MMM-yy h:mm:ss tt
d-MMM-yy hh:mm:ss tt
d-MMM-yy HH:mm:ss
d-MMM-yy H:mm:ss
dddd, MMMM dd, yyyy h:mm:ss tt
dddd, MMMM dd, yyyy hh:mm:ss tt
dddd, MMMM dd, yyyy HH:mm:ss
dddd, MMMM dd, yyyy H:mm:ss
MMMM, yyyy
MMMM, yyyy
你应该使用:
DateTime.ParseExact("05/22/2014",
<your expected format>,
Cultureinfo.InvariantCulture);
这是最适合我的代码,感谢大家的回复。
private String FormatDate(String _Date)
{
DateTime Dt = DateTime.Now;
IFormatProvider mFomatter = new System.Globalization.CultureInfo("en-US");
Dt = DateTime.Parse(_Date, mFomatter);
return Dt.ToString("yyyy-MM-dd");
}