以任何格式将字符串转换为datetime

时间:2016-04-22 12:05:47

标签: c# datetime datetime-format cultureinfo

目标

希望将任何格式的日期时间转换为de-DE文化

日期时间

3/30/2016 2:38:20 PM

2016/4/4 11:08:10

我尝试了什么

protected void Page_Load(object sender, EventArgs e)
{
    string dt1Valid = CheckDateFormat("3/30/2016 2:38:20 PM");
}

public string CheckDateFormat(string checkDate)
{
    string formats1 = getFormat(checkDate);

    DateTime parsedDateTime;
    DateTimeFormatInfo ukDtfi = new CultureInfo("de-DE", false).DateTimeFormat;
    if (!DateTime.TryParseExact(checkDate, formats1, new CultureInfo("de-DE"),
                                   DateTimeStyles.None, out parsedDateTime))
    {
        return Convert.ToDateTime(parsedDateTime.ToString()).ToString(ukDtfi.ShortDatePattern + " " + ukDtfi.LongTimePattern);

    }
    else
        return "";
}
public string getFormat(string checkDate)
{
    string[] formats = {"M/d/yyyy", "MM/dd/yyyy",                                    
                    "d/M/yyyy", "dd/MM/yyyy", 
                    "yyyy/M/d", "yyyy/MM/dd",
                    "M-d-yyyy", "MM-dd-yyyy",                                    
                    "d-M-yyyy", "dd-MM-yyyy", 
                    "yyyy-M-d", "yyyy-MM-dd",
                    "M.d.yyyy", "MM.dd.yyyy",                                    
                    "d.M.yyyy", "dd.MM.yyyy", 
                    "yyyy.M.d", "yyyy.MM.dd",
                    "M,d,yyyy", "MM,dd,yyyy",                                    
                    "d,M,yyyy", "dd,MM,yyyy", 
                    "yyyy,M,d", "yyyy,MM,dd",
                    "M d yyyy", "MM dd yyyy",                                    
                    "d M yyyy", "dd MM yyyy", 
                    "yyyy M d", "yyyy MM dd",

                    "M/d/yyyy hh:mm:ss tt", "MM/dd/yyyy hh:mm:ss tt",                                    
                    "d/M/yyyy hh:mm:ss tt", "dd/MM/yyyy hh:mm:ss tt", 
                    "yyyy/M/d hh:mm:ss tt", "yyyy/MM/dd hh:mm:ss tt",
                    "M-d-yyyy hh:mm:ss tt", "MM-dd-yyyy hh:mm:ss tt",                                    
                    "d-M-yyyy hh:mm:ss tt", "dd-MM-yyyy hh:mm:ss tt", 
                    "yyyy-M-d hh:mm:ss tt", "yyyy-MM-dd hh:mm:ss tt",
                    "M.d.yyyy hh:mm:ss tt", "MM.dd.yyyy hh:mm:ss tt",                                    
                    "d.M.yyyy hh:mm:ss tt", "dd.MM.yyyy hh:mm:ss tt", 
                    "yyyy.M.d hh:mm:ss tt", "yyyy.MM.dd hh:mm:ss tt",
                    "M,d,yyyy hh:mm:ss tt", "MM,dd,yyyy hh:mm:ss tt",                                    
                    "d,M,yyyy hh:mm:ss tt", "dd,MM,yyyy hh:mm:ss tt", 
                    "yyyy,M,d hh:mm:ss tt", "yyyy,MM,dd hh:mm:ss tt",
                    "M d yyyy hh:mm:ss tt", "MM dd yyyy hh:mm:ss tt",                                    
                    "d M yyyy hh:mm:ss tt", "dd MM yyyy hh:mm:ss tt", 
                    "yyyy M d hh:mm:ss tt", "yyyy MM dd hh:mm:ss tt"

                   };

    DateTime dateValue;

    foreach (string dateStringFormat in formats)
    {
        if (DateTime.TryParseExact(checkDate, dateStringFormat,
                                   CultureInfo.InvariantCulture,
                                   DateTimeStyles.None,
                                   out dateValue))
            //Console.WriteLine("Converted '{0}' to {1}.", dateStringFormat, dateValue.ToString("yyyy-MM-dd"));                
            return dateStringFormat;
    }
    return null;
}

我期待的结果

30.03.2016 14:38:20
04.04.2016 11:08:10

结果我

01.01.0001 00:00:00
01.01.0001 00:00:00

1 个答案:

答案 0 :(得分:7)

这很容易回答:这是不可能的,所以不要再尝试了。

证明:任何格式包括M.d.yyyy以及d.M.yyyy。在这种情况下,1.2.2016可以代表

  • 二月一日或
  • 1月2日。

结论:无法从任何格式进行翻译,因为如果没有其他信息,就无法解析模糊日期。

注意:这与C#或您选择的技术无关。您的要求已损坏。修复它们。