DateTime.TryParse问题,日期为yyyy-dd-MM格式

时间:2011-01-17 23:20:24

标签: c# asp.net datetime date tryparse

我的字符串格式为“2011-29-01 12:00 am”。现在我尝试使用以下代码将其转换为datetime格式:

DateTime.TryParse(dateTime, out dt); 

但我总是在{1/1/0001 12:00:00 AM}获得dt,你能告诉我为什么吗?以及如何将该字符串转换为日期。

编辑:我刚看到提到的每个人都使用格式参数。我现在要提到的是我不能使用format参数,因为我有一些设置来选择用户想要的自定义dateformat,并且基于该用户能够通过jQuery datepicker自动以该格式获取文本框中的日期。

7 个答案:

答案 0 :(得分:159)

这应该基于您的示例“2011-29-01 12:00 am”

DateTime dt;
DateTime.TryParseExact(dateTime, 
                       "yyyy-dd-MM hh:mm tt", 
                       CultureInfo.InvariantCulture, 
                       DateTimeStyles.None, 
                       out dt);

答案 1 :(得分:12)

您需要使用ParseExact method。这会将字符串作为第二个参数,指定日期时间所在的格式,例如:

// Parse date and time with custom specifier.
dateString = "2011-29-01 12:00 am";
format = "yyyy-dd-MM h:mm tt";
try
{
   result = DateTime.ParseExact(dateString, format, provider);
   Console.WriteLine("{0} converts to {1}.", dateString, result.ToString());
}
catch (FormatException)
{
   Console.WriteLine("{0} is not in the correct format.", dateString);
}

如果用户可以在UI中指定格式,则需要将其转换为可以传递给此方法的字符串。你可以通过允许用户直接输入格式字符串来做到这一点 - 虽然这意味着转换更可能失败,因为他们输入无效的格式字符串 - 或者有一个组合框提示他们有可能的选择,你可以为这些选择设置格式字符串。

如果输入可能不正确(例如用户输入),最好使用TryParseExact而不是使用异常来处理错误情况:

// Parse date and time with custom specifier.
dateString = "2011-29-01 12:00 am";
format = "yyyy-dd-MM h:mm tt";
DateTime result;
if (DateTime.TryParseExact(dateString, format, provider, DateTimeStyles.None, out result))
{
   Console.WriteLine("{0} converts to {1}.", dateString, result.ToString());
}
else
{
   Console.WriteLine("{0} is not in the correct format.", dateString);
}

更好的选择可能是为用户提供日期格式选择,但请使用overload that takes an array of formats

// A list of possible American date formats - swap M and d for European formats
string[] formats= {"M/d/yyyy h:mm:ss tt", "M/d/yyyy h:mm tt", 
                   "MM/dd/yyyy hh:mm:ss", "M/d/yyyy h:mm:ss", 
                   "M/d/yyyy hh:mm tt", "M/d/yyyy hh tt", 
                   "M/d/yyyy h:mm", "M/d/yyyy h:mm", 
                   "MM/dd/yyyy hh:mm", "M/dd/yyyy hh:mm",
                   "MM/d/yyyy HH:mm:ss.ffffff" };
string dateString; // The string the date gets read into

try
{
    dateValue = DateTime.ParseExact(dateString, formats, 
                                    new CultureInfo("en-US"), 
                                    DateTimeStyles.None);
    Console.WriteLine("Converted '{0}' to {1}.", dateString, dateValue);
}
catch (FormatException)
{
    Console.WriteLine("Unable to convert '{0}' to a date.", dateString);
}                                               

如果您从配置文件或数据库中读取可能的格式,那么您可以在遇到人们想要输入日期的所有不同方式时添加这些格式。

答案 2 :(得分:4)

来自msdn上的DateTime

  

类型:System.DateTime%此方法返回时,包含DateTime   值相当于s中包含的日期和时间,如果是   转换成功,如果转换失败,则 MinValue 。该   如果s参数为null,则转换失败,为空字符串(“”),   或者不包含日期和时间的有效字符串表示形式。   此参数未初始化传递。

请使用格式字符串为"yyyy-dd-MM hh:mm tt"的parseexact。

答案 3 :(得分:3)

有效:

DateTime dt = DateTime.ParseExact("2011-29-01 12:00 am", "yyyy-dd-MM hh:mm tt", System.Globalization.CultureInfo.InvariantCulture);

答案 4 :(得分:3)

尝试使用安全的TryParseExact方法

DateTime temp;
string   date = "2011-29-01 12:00 am";

DateTime.TryParseExact(date, "yyyy-dd-MM hh:mm tt", CultureInfo.InvariantCulture, DateTimeStyles.None, out temp);

答案 5 :(得分:1)

DateTime dt = DateTime.ParseExact("11-22-2012 12:00 am", "MM-dd-yyyy hh:mm tt", System.Globalization.CultureInfo.InvariantCulture);

答案 6 :(得分:0)

如果您为用户提供更改日期/时间格式的机会,则必须创建用于解析的相应格式字符串。如果你知道可能的日期格式(即用户必须从列表中选择),那么这就容易得多,因为你可以在编译时创建这些格式字符串。

如果让用户进行日期/时间格式的自由格式设计,则必须在运行时创建相应的DateTime格式字符串。