91

我有以下字符串格式的日期 "2011-29-01 12:00 am" 。现在我正在尝试使用以下代码将其转换为日期时间格式:

DateTime.TryParse(dateTime, out dt); 

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

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

4

7 回答 7

205

这应该根据您的示例“2011-29-01 12:00 am”起作用

DateTime dt;
DateTime.TryParseExact(dateTime, 
                       "yyyy-dd-MM hh:mm tt", 
                       CultureInfo.InvariantCulture, 
                       DateTimeStyles.None, 
                       out dt);
于 2011-01-17T23:32:49.273 回答
15

你需要使用ParseExact方法。这需要一个字符串作为它的第二个参数,它指定日期时间的格式,例如:

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

更好的选择可能是向用户提供日期格式的选择,而是使用采用格式数组的重载

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

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

这种方法的主要缺点是您仍然会有模棱两可的日期。这些格式是按顺序尝试的,所以无论它会在美国之前尝试欧洲格式(反之亦然),并涵盖日期小于 13 到欧洲格式日期的任何内容,即使用户认为他们正在输入美国格式化日期。

于 2011-01-17T23:31:13.737 回答
7

尝试使用安全的 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);
于 2012-04-27T16:05:48.927 回答
4

来自msdn 上的DateTime :

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

改为使用带有格式字符串的 parseexact "yyyy-dd-MM hh:mm tt"

于 2011-01-17T23:28:32.200 回答
3

这样可行:

DateTime dt = DateTime.ParseExact("2011-29-01 12:00 am", "yyyy-dd-MM hh:mm tt", System.Globalization.CultureInfo.InvariantCulture);
于 2011-01-17T23:33:56.300 回答
1
DateTime dt = DateTime.ParseExact("11-22-2012 12:00 am", "MM-dd-yyyy hh:mm tt", System.Globalization.CultureInfo.InvariantCulture);
于 2012-11-19T12:33:02.563 回答
0

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

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

于 2011-01-18T00:06:24.947 回答