Конвертировать 20121004 (yyyyMMdd) в действительное время?
У меня есть строка в следующем форматеyyyyMMdd
и я пытаюсь заставить его выглядеть так:
yyyy-MM-dd
Когда я пытаюсь:
string date = "20121004";
Convert.ToDateTime(date).ToString("yyyy-MM-dd");
Я получаю ошибку:
FormatException: String was not recognized as a valid DateTime.
Будет ли следующая работа или я столкнусь с проблемой:
private string GetValidDate(string date,string format)
{
DateTime result;
if(DateTime.TryParseExact(date, "yyyy-MM-dd", CultureInfo.InvariantCulture, DateTimeStyles.None, out result))
{
return date;
}
else if(DateTime.TryParseExact(date, "yyyyMMdd", CultureInfo.InvariantCulture, DateTimeStyles.None, out result))
{
return DateTime.ParseExact(date, "yyyyMMdd",
CultureInfo.InvariantCulture).ToString("yyyy-MM-dd");
}
else
{
return "Invalid Date Format";
}
}