C # DateTime to «ГГГГММДДЧЧММСС» формат

Я хочу преобразовать C # DateTime в формат "ГГГГММДДЧЧММСС". Но я не нашел встроенный метод, чтобы получить этот формат? Любые комментарии?

вопрос задан 11.06.2010
SARAVAN
4554 репутация

13 ответов


  • 863 рейтинг
    DateTime.Now.ToString("yyyyMMddHHmmss"); // case sensitive
    
    ответ дан Jim Lamb, с репутацией 19799, 11.06.2010
  • 480 рейтинг

    На этом сайте есть отличные примеры проверить

    // create date time 2008-03-09 16:05:07.123
    DateTime dt = new DateTime(2008, 3, 9, 16, 5, 7, 123);
    
    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
    
    // month/day numbers without/with leading zeroes
    String.Format("{0:M/d/yyyy}",           dt);  // "3/9/2008"
    String.Format("{0:MM/dd/yyyy}",         dt);  // "03/09/2008"
    
    // day/month names
    String.Format("{0:ddd, MMM d, yyyy}",   dt);  // "Sun, Mar 9, 2008"
    String.Format("{0:dddd, MMMM d, yyyy}", dt);  // "Sunday, March 9, 2008"
    
    // two/four digit year
    String.Format("{0:MM/dd/yy}",           dt);  // "03/09/08"
    String.Format("{0:MM/dd/yyyy}",         dt);  // "03/09/2008"
    

    Стандартное форматирование даты и времени

    String.Format("{0:t}", dt);  // "4:05 PM"                           ShortTime
    String.Format("{0:d}", dt);  // "3/9/2008"                          ShortDate
    String.Format("{0:T}", dt);  // "4:05:07 PM"                        LongTime
    String.Format("{0:D}", dt);  // "Sunday, March 09, 2008"            LongDate
    String.Format("{0:f}", dt);  // "Sunday, March 09, 2008 4:05 PM"    LongDate+ShortTime
    String.Format("{0:F}", dt);  // "Sunday, March 09, 2008 4:05:07 PM" FullDateTime
    String.Format("{0:g}", dt);  // "3/9/2008 4:05 PM"                  ShortDate+ShortTime
    String.Format("{0:G}", dt);  // "3/9/2008 4:05:07 PM"               ShortDate+LongTime
    String.Format("{0:m}", dt);  // "March 09"                          MonthDay
    String.Format("{0:y}", dt);  // "March, 2008"                       YearMonth
    String.Format("{0:r}", dt);  // "Sun, 09 Mar 2008 16:05:07 GMT"     RFC1123
    String.Format("{0:s}", dt);  // "2008-03-09T16:05:07"               SortableDateTime
    String.Format("{0:u}", dt);  // "2008-03-09 16:05:07Z"              UniversalSortableDateTime
    
    /*
    Specifier   DateTimeFormatInfo property     Pattern value (for en-US culture)
        t           ShortTimePattern                    h:mm tt
        d           ShortDatePattern                    M/d/yyyy
        T           LongTimePattern                     h:mm:ss tt
        D           LongDatePattern                     dddd, MMMM dd, yyyy
        f           (combination of D and t)            dddd, MMMM dd, yyyy h:mm tt
        F           FullDateTimePattern                 dddd, MMMM dd, yyyy h:mm:ss tt
        g           (combination of d and t)            M/d/yyyy h:mm tt
        G           (combination of d and T)            M/d/yyyy h:mm:ss tt
        m, M        MonthDayPattern                     MMMM dd
        y, Y        YearMonthPattern                    MMMM, yyyy
        r, R        RFC1123Pattern                      ddd, dd MMM yyyy HH':'mm':'ss 'GMT' (*)
        s           SortableDateTi­mePattern             yyyy'-'MM'-'dd'T'HH':'mm':'ss (*)
        u           UniversalSorta­bleDateTimePat­tern    yyyy'-'MM'-'dd HH':'mm':'ss'Z' (*)
                                                        (*) = culture independent   
    */
    

    Обновление используя c # 6 формат строки интерполяции

    // create date time 2008-03-09 16:05:07.123
    DateTime dt = new DateTime(2008, 3, 9, 16, 5, 7, 123);
    
    $"{dt:y yy yyy yyyy}";  // "8 08 008 2008"   year
    $"{dt:M MM MMM MMMM}";  // "3 03 Mar March"  month
    $"{dt:d dd ddd dddd}";  // "9 09 Sun Sunday" day
    $"{dt:h hh H HH}";      // "4 04 16 16"      hour 12/24
    $"{dt:m mm}";           // "5 05"            minute
    $"{dt:s ss}";           // "7 07"            second
    $"{dt:f ff fff ffff}";  // "1 12 123 1230"   sec.fraction
    $"{dt:F FF FFF FFFF}";  // "1 12 123 123"    without zeroes
    $"{dt:t tt}";           // "P PM"            A.M. or P.M.
    $"{dt:z zz zzz}";       // "-6 -06 -06:00"   time zone
    
    // month/day numbers without/with leading zeroes
    $"{dt:M/d/yyyy}";    // "3/9/2008"
    $"{dt:MM/dd/yyyy}";  // "03/09/2008"
    
    // day/month names
    $"{dt:ddd, MMM d, yyyy}";    // "Sun, Mar 9, 2008"
    $"{dt:dddd, MMMM d, yyyy}";  // "Sunday, March 9, 2008"
    
    // two/four digit year
    $"{dt:MM/dd/yy}";    // "03/09/08"
    $"{dt:MM/dd/yyyy}";  // "03/09/2008"
    
    ответ дан Moes, с репутацией 8713, 14.07.2014
  • 239 рейтинг

    Вы практически написали формат самостоятельно.

    yourdate.ToString("yyyyMMddHHmmss")

    • MM = двузначный месяц
    • мм = двузначные минуты
    • ЧЧ = двузначный час, 24-часовые часы
    • чч = двузначный час, 12-часовые часы

    Все остальное должно быть само за себя.

    ответ дан Anthony Pegram, с репутацией 95109, 11.06.2010
  • 126 рейтинг

    Вы просто должны быть осторожны между месяцами (ММ) и минутами (мм):

    DateTime dt = DateTime.Now; // Or whatever
    string s = dt.ToString("yyyyMMddHHmmss");
    

    (Также обратите внимание, что HH - это 24-часовые часы, тогда как hh - это 12-часовые часы, обычно в сочетании с t или tt для обозначения am / pm. )

    Если вы хотите сделать это как часть строки составного формата, вы должны использовать:

    string s = string.Format("The date/time is: {0:yyyyMMddHHmmss}", dt);
    

    Для получения дополнительной информации см. Страницу MSDN о пользовательских форматах даты и времени .

    ответ дан Jon Skeet, с репутацией 1057123, 11.06.2010
  • 25 рейтинг

    Вы можете использовать пользовательский формат строки:

    DateTime d = DateTime.Now;
    string dateString = d.ToString("yyyyMMddHHmmss");
    

    Замените «чч» на «чч», если вы не хотите использовать 24-часовое время.

    ответ дан Paul Kearney - pk, с репутацией 4600, 11.06.2010
  • 20 рейтинг

    Если вы используете ReSharper, обратитесь за помощью к ':' (см. Изображение)

    Intellisense

    ответ дан Georg, с репутацией 917, 6.11.2015
  • 18 рейтинг
    DateTime.Now.ToString("yyyyMMddHHmmss");
    

    , если вы просто хотите, чтобы он отображался в виде строки

    ответ дан Pharabus, с репутацией 5601, 11.06.2010
  • 9 рейтинг
    string date = DateTime.Now.ToString("dd-MMM-yy");  //05-Aug-13
    
    ответ дан Zohaib Iqbal, с репутацией 190, 5.08.2013
  • 8 рейтинг

    Я удивлен, что ни у кого нет ссылки для этого. Любой формат может быть создан с использованием инструкций здесь:

    Пользовательские строки формата даты и времени

    Для вашего конкретного примера (как указали другие) используйте что-то вроде

    my_format="yyyyMMddHHmmss";
    DateTime.Now.ToString(my_format);
    

    Где my_format может быть любой комбинацией строк y, M, H, m, s, f, F и других! Проверьте ссылку.

    ответ дан joecop, с репутацией 680, 1.07.2014
  • 7 рейтинг

    В .Net Standard 2 вы можете отформатировать DateTime как показано ниже:

    DateTime dt = DateTime.Now;
    CultureInfo iv = CultureInfo.InvariantCulture;
    
    // Default formats
    // D - long date           Tuesday, 24 April 2018
    // d - short date          04/24/2018
    // F - full date long      Tuesday, 24 April 2018 06:30:00
    // f - full date short     Tuesday, 24 April 2018 06:30
    // G - general long        04/24/2018 06:30:00
    // g - general short       04/24/2018 06:30
    // U - universal full      Tuesday, 24 April 2018 06:30:00
    // u - universal sortable  2018-04-24 06:30:00
    // s - sortable            2018-04-24T06:30:00
    // T - long time           06:30:00
    // t - short time          06:30
    // O - ISO 8601            2018-04-24T06:30:00.0000000
    // R - RFC 1123            Tue, 24 Apr 2018 06:30:00 GMT           
    // M - month               April 24
    // Y - year month          2018 April
    Console.WriteLine(dt.ToString("D", iv));
    
    // Custom formats
    // M/d/yy                  4/8/18
    // MM/dd/yyyy              04/08/2018
    // yy-MM-dd                08-04-18
    // yy-MMM-dd ddd           08-Apr-18 Sun
    // yyyy-M-d dddd           2018-4-8 Sunday
    // yyyy MMMM dd            2018 April 08      
    // h:mm:ss tt zzz          4:03:05 PM -03
    // HH:m:s tt zzz           16:03:05 -03:00
    // hh:mm:ss t z            04:03:05 P -03
    // HH:mm:ss tt zz          16:03:05 PM -03      
    Console.WriteLine(dt.ToString("M/d/yy", iv));
    
    ответ дан Sina Lotfi, с репутацией 710, 24.05.2018
  • 2 рейтинг

    с использованием C # 6. 0

    $"Date-{DateTime.Now:yyyyMMddHHmmss}"
    
    ответ дан Waleed A.K., с репутацией 898, 26.07.2016
  • 1 рейтинг

    Простой метод, полный контроль над «от типа» и «для типа», и нужно только запомнить этот код для будущих кастингов

    DateTime.ParseExact(InputDate, "dd/MM/yyyy", CultureInfo.InvariantCulture).ToString("yyyy/MM/dd"));
    
    ответ дан Arun Prasad E S, с репутацией 3281, 29.02.2016
  • -1 рейтинг

    Потратив много часов на поиск в Google, я нашел следующее решение: когда я локально даю время, без каких-либо исключений на другом сервере, произошла ошибка. , , , , , , , , Дата не в правильном формате. , Перед сохранением / поиском даты и времени в текстовом поле в C # просто проверьте, является ли внешняя культура сервера такой же, как культура сервера базы данных. , Ex оба должны быть "en-US" или должны быть оба "en-GB" asp ниже снимка.

    enter image description here

    Даже с другим форматом даты, таким как (дд / мм / гггг) или (гггг / мм / дд), он будет сохранять или искать точно.

    ответ дан Ayaat Shifa, с репутацией 687, 16.10.2017