Преобразование строки даты в другую строку даты с другим форматом

Мне нужно преобразовать строку даты с форматом yyyyMMdd в строку даты с форматом MM/dd/yyyy. Что лучше сделать?

Я делаю это:

DateTime.ParseExact(dateString, "yyyyMMdd", CultureInfo.InvariantCulture).ToString("MM/dd/yyyy")

Но я не уверен, я думаю, что должен быть лучший способ. Что вы думаете?


person Müsli    schedule 16.09.2013    source источник
comment
твой путь - лучший способ, я думаю.   -  person King King    schedule 16.09.2013
comment
еще не придумал лучшего способа, чем этот :)   -  person internals-in    schedule 16.09.2013
comment
Есть ли причина, по которой вам нужно переформатировать строку? Звучит так, как будто вы на самом деле форматируете строку даты из базы данных, я прав? Затем сохраните его как datetime в первую очередь.   -  person Tim Schmelter    schedule 16.09.2013


Ответы (4)


То, что вы делаете, прекрасно.

Вероятно, вы можете улучшить его, используя DateTime.TryParseExact и в случае успеха синтаксический анализ, отформатируйте объект DateTime в другом формате.

string dateString = "20130916";
DateTime parsedDateTime;
string formattedDate;
if(DateTime.TryParseExact(dateString, "yyyyMMdd", 
                    CultureInfo.InvariantCulture, 
                    DateTimeStyles.None, 
                    out parsedDateTime))
{
    formattedDate = parsedDateTime.ToString("MM/dd/yyyy");
}
else
{
       Console.WriteLine("Parsing failed");
}
person Habib    schedule 16.09.2013

Ваш способ полностью в порядке. Вы можете попробовать сделать это: -

string res = "20130908";
DateTime d = DateTime.ParseExact(res, "yyyyMMdd", CultureInfo.InvariantCulture);
Console.WriteLine(d.ToString("MM/dd/yyyy"));

Просто для справки из MSDN: -

Метод DateTime.ParseExact(String, String, IFormatProvider) анализирует строковое представление даты, которое должно быть в формате, определяемом параметром формата.

person Rahul Tripathi    schedule 16.09.2013
comment
В вопросе указано yyyyMMdd... ваш пример точно такой же, но с yyyyddMM? - person crashmstr; 16.09.2013

Ваш код на самом деле лучший (конечно, лучше использовать TryParseExact), однако похоже, что ваша входная строка имеет правильный формат (может быть преобразована в DateTime), вы просто хотите переформатировать ее, я думаю использование некоторого строкового метода поможет. Но я хотел бы использовать Regex здесь:

string output = Regex.Replace(input, "^(\\d{4})(\\d{2})(\\d{2})$", "$2/$3/$1");
//E.g
input = "20130920";
output = "09/20/2013";
person King King    schedule 16.09.2013

string date = "01/08/2008";
DateTime dt = Convert.ToDateTime(date);     //or       
DateTime dt = DateTime.Parse(date, culture, System.Globalization.DateTimeStyles.AssumeLocal); //or       
// create date time 2008-03-09 16:05:07.123
DateTime dt = new DateTime(2008, 3, 9, 16, 5, 7, 123); //or       

Теперь отформатируйте, как вам нравится dt ...

String.Format("{0:y yy yyy yyyy}", dt);  // "8 08 008 2008"   year
String.Format("{0:M MM MMM MMMM}", dt);  // "3 03 Mar March"  month
String.Format("{0:d dd ddd dddd}", dt);  // "9 09 Sun Sunday" day
String.Format("{0:h hh H HH}",     dt);  // "4 04 16 16"      hour 12/24
String.Format("{0:m mm}",          dt);  // "5 05"            minute
String.Format("{0:s ss}",          dt);  // "7 07"            second
String.Format("{0:f ff fff ffff}", dt);  // "1 12 123 1230"   sec.fraction
String.Format("{0:F FF FFF FFFF}", dt);  // "1 12 123 123"    without zeroes
String.Format("{0:t tt}",          dt);  // "P PM"            A.M. or P.M.
String.Format("{0:z zz zzz}",      dt);  // "-6 -06 -06:00"   time zone

Часть формата от As from www.csharp-examples.net

person internals-in    schedule 16.09.2013