从各种字符串创建DateTime对象

时间:2014-12-04 12:11:40

标签: c# string datetime datetime-parsing

我有一个日期格式的字符串。我想将其转换为DateTime对象。但是我不确定字符串的格式。

我是否可以使用任何方法使其适用于以下输入?

"12/31/2015", "31/12/2015", "2015-12-31"

4 个答案:

答案 0 :(得分:4)

您可以将TryParseExact与预期格式列表一起使用。

string[] formats = { "MM/dd/yyyy", "dd/MM/yyyy", "yyyy-MM-dd" };
DateTime outputDate;
DateTime.TryParseExact(inputText, formats, 
    CultureInfo.InvariantCulture, DateTimeStyles.None, out outputDate)

答案 1 :(得分:4)

DateTime.TryParseExact method has an overload将您的格式作为字符串数组。

string s = "";
DateTime dt;
var array = new[] {"MM/dd/yyyy", "dd/MM/yyyy", "yyyy-MM-dd"};
if(DateTime.TryParseExact(s, array, CultureInfo.InvariantCulture,
                          DateTimeStyles.None, out dt))
{
    //
}

我使用InvariantCulture作为IFormatProvider,因为/ format specifier具有的特殊含义将我替换为当前文化或提供的文化日期分隔符。这意味着,如果您使用CurrentCulture并且/没有DateSeparator,那么如果您的字符串和格式完全匹配,那么您的解析将失败甚至

但请记住

这种方式对你的例子很有用。

01/02/2015之类的字符串是一个问题,因为此方法无法知道这是1 February 20152 January 2015。在这种情况下,此方法会使用第一个成功匹配的格式解析您的字符串。

  

但是我不确定字符串的格式。

如果您想完全成功解析所有示例,必须知道其确切格式。

答案 2 :(得分:0)

您可以使用允许的文化列表:

        var list = new List<string> {"12/31/2015", "31/12/2015", "2015-12-31"};
        var allowedCultures = CultureInfo.GetCultures(CultureTypes.AllCultures);

        foreach (string s in list)
        {
            DateTime dt;
            foreach (CultureInfo culture in allowedCultures)
            {
                if (DateTime.TryParse(s, culture, DateTimeStyles.None, out dt))
                {
                    Console.WriteLine("{0} - {1}", culture.DisplayName, dt.ToShortDateString());
                    break;
                }
            }
        }

答案 3 :(得分:0)

您可以使用DateTime.Parse。试试这段代码:

// Define cultures to be used to parse dates.
      CultureInfo[] cultures = {CultureInfo.CreateSpecificCulture("en-US"), 
                                CultureInfo.CreateSpecificCulture("fr-FR"), 
                                CultureInfo.CreateSpecificCulture("de-DE")};
      // Define string representations of a date to be parsed. 
      string[] dateStrings = {"01/10/2009 7:34 PM", 
                              "10.01.2009 19:34", 
                              "10-1-2009 19:34" };
      // Parse dates using each culture. 
      foreach (CultureInfo culture in cultures)
      {
         DateTime dateValue;
         Console.WriteLine("Attempted conversions using {0} culture.", 
                           culture.Name);
         foreach (string dateString in dateStrings)
         {
            try {
               dateValue = DateTime.Parse(dateString, culture);
               Console.WriteLine("   Converted '{0}' to {1}.",
                                 dateString, dateValue.ToString("f", culture));
            }
            catch (FormatException) {
               Console.WriteLine("   Unable to convert '{0}' for culture {1}.", 
                                 dateString, culture.Name);
            }
         }
         Console.WriteLine();

Source