用户代码datetime未处理FormatException

时间:2014-05-22 18:44:12

标签: c# datetime

当我尝试从文本框中获取日期值时,值为:"05/22/2014" 我想将它插入我的数据库字段,该字段具有日期时间格式,所以我想先转换它。所以我在文本框的text属性的值上使用Convert.ToDateTime函数。但我收到一个错误说

  

FormatException未被用户代码处理。字符串不是   被认为是有效的DateTime。

当我在文本框文本值上使用Convert.ToDateTime时,我不知道该怎么做?

<asp:TextBox ID="cldStartProj" CssClass="datePicker" TextMode="DateTime" runat="server"></asp:TextBox> 
DateTime dtDateStart = Convert.ToDateTime(cldStartProj.Text);

3 个答案:

答案 0 :(得分:1)

默认情况下,

Convert.ToDateTime(string)使用CurrentCulture。这是怎样的implemented;

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.TryParseExactDateTime.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在自定义日期和格式字符串中有特殊含义。这意味着将我替换为当前的文化日期分隔符。这意味着即使您的字符串格式完全相同,如果DateSeparator property不是/,您的解析操作也会失败。

  

该物业是&#39; en-ca&#39;

正如我所说,你的文化并不像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

答案 1 :(得分:0)

您应该使用:

DateTime.ParseExact("05/22/2014",
                    <your expected format>,
                    Cultureinfo.InvariantCulture);

答案 2 :(得分:-1)

这是最适合我的代码,感谢大家的回复。

 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");
        }