C#DateTimeから「YYYYMMDDHHMMSS」形式


621

C#のDateTimeを "YYYYMMDDHHMMSS"形式に変換したい。しかし、私はこのフォーマットを取得するための組み込みメソッドを見つけられませんか?コメントは?

回答:


1061
DateTime.Now.ToString("yyyyMMddHHmmss"); // case sensitive

35
何ヶ月も大きなMがあり、何時間も大きなHがあるのはおかしいと思うのは私だけですか?
Nick

69
m =分/ M =月、h = 12時間、H = 24時間。私は誰かが時間から始まって、hms =時間分秒と言ったのではないかと思います。その後、Hは24時間になり、日付が変わって一意の文字が足りなくなったため、大文字と小文字を区別しました。それらの1つだけです。
ダグラスアンダーソン

2
使用してそれをどのように解析しDateTime.Parse()ますか?
ビッグマネー

12
@BigMoney DateTime.ParseExactを使用します。var now = DateTime.ParseExact(stringVersion、 "YYYYMMDDHHMMSS"、CultureInfo.InvariantCulture);
ジム・ラム

4
@BigMoney解析するとき、formatすなわち、また、大文字と小文字が区別されますDateTime.ParseExact(stringValue, "yyyyMMddHHmmss", CultureInfo.InvariantCulture);
ナイジェルタッチ

577

このサイトは、偉大な例があり、それをチェックアウト

// 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"

この形式を希望します。 yyyyMMddHHmm[+-]ZZzzここで、[+-] ZZzzの部分はタイムゾーン(GMT日付から加算または
減算

zzzある-06:00、私は希望-0600
Kiquenet

2
@Kiquenetは回避策.Replace(":", "") $"{dt:yyyyMMddHHmmzzz}".Replace(":", "")として試しましたか
Nerdroid 2017

別の方法はですdt.ToString("...");。ここ"..."で、上記のフォーマットに置き換えます。"yyyy-MM-dd"
ToolmakerSteve

247

あなたは実際に自分でフォーマットを書きました。

yourdate.ToString("yyyyMMddHHmmss")

  • MM = 2桁の月
  • mm = 2桁の分
  • HH = 2桁の時間、24時間制
  • hh = 2桁の時間、12時間時計

他のすべては自明でなければなりません。


92
"fff"はミリ秒を与えるため、 "yyyyMMddHHmmssfff"を使用してミリ秒までの文字列を与えることができます。
ジェフウィドマー2011

タイムゾーンの一部(GMT日付から加算または減算される時間数)はどれですか?
Kiquenet 2017年

129

月(MM)と分(mm)の間で注意する必要があります。

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

(また、HHは24時間制であるのに対し、hhは12時間制であり、通常はam / pm指定子のtまたはttと組み合わせて使用​​します。)

これを複合フォーマット文字列の一部として行う場合は、次のようにします。

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

詳細については、MSDNページのカスタムの日付と時刻の形式を参照してください


それは可能now.ToString("yyyyMMdd_HHmmss")ですか?つまり、他の文字と連結することは可能ですか?
DanielV 2015

1
@DanielV:はい、しかし私はリテラル文字を(アポストロフィで)引用します。
Jon Skeet

26

カスタムのフォーマット文字列を使用できます。

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

24時間制の時刻が必要ない場合は、「HH」を「hh」に置き換えます。


21

ReSharperを使用している場合は、「:」のヘルプを参照してください(画像を参照)

Intellisense


ReSharperを使用すると、2013年も(おそらく以前も)同じことが実現します。
Wai Ha Lee


16

以下のように.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));


8

誰もこれにリンクがないことに驚いています。以下のガイドラインを使用して、任意の形式を作成できます。

カスタムの日付と時刻のフォーマット文字列

あなたの具体的な例(他の人が示したように)のようなものを使用してください

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

my_formatは、y、M、H、m、s、f、Fなどの文字列の組み合わせです。リンクをチェックしてください。


1
ジョンスキートはそのリンクを回答に含めました(stackoverflow.com/a/3025377/12484)。
Jon Schneider 14

5

DateTime文字列ではなくオブジェクトとして日付を取得します。その後、必要に応じてフォーマットできます。

  • MM / dd / yyyy 08/22/2006
  • dddd、dd MMMM yyyy 2006年8月22日火曜日
  • dddd、dd MMMM yyyy HH:mm 2006年8月22日火曜日06:30
  • dddd、dd MMMM yyyy hh:mm tt 2006年8月22日火曜日06:30 AM
  • dddd、dd MMMM yyyy H:mm 2006年8月22日火曜日6:30
  • dddd、dd MMMM yyyy h:mm tt 2006年8月22日火曜日6:30 AM
  • dddd、dd MMMM yyyy HH:mm:ss 2006年8月22日火曜日06:30:07
  • MM / dd / yyyy HH:mm 2006年8月22日06:30
  • MM / dd / yyyy hh:mm tt 2006年8月22日06:30 AM
  • MM / dd / yyyy H:mm 08/22/2006 6:30
  • MM / dd / yyyy h:mm tt 2006年8月22日6:30 AM
  • MM / dd / yyyy HH:mm:ss 2006年8月22日06:30:07

その他のパタ​​ーンはこちらをクリックしてください



3

簡単な方法、「from type」と「to type」を完全に制御し、将来のキャストのためにこのコードを覚えるだけでよい

DateTime.ParseExact(InputDate, "dd/MM/yyyy", CultureInfo.InvariantCulture).ToString("yyyy/MM/dd"));

2

大したことじゃないよ。あなたは単にこのように置くことができます

WriteLine($"{DateTime.Now.ToString("yyyy-MM-dd-HH:mm:ss")}");

文字列の補間のために$を使用したので、ここで言い訳をしてください。


0

上記のいずれの回答でも問題が解決しない可能性は非常に低いです。それでも、日付時刻のさまざまな形式で常に機能する方法を共有しています。

//Definition   
     public static DateTime ConvertPlainStringToDatetime(string Date, string inputFormat, string  outputFormat)
            {
                DateTime date;
                CultureInfo enUS = new CultureInfo("en-US");
                DateTime.TryParseExact(Date, inputFormat, enUS,
                                    DateTimeStyles.AdjustToUniversal, out date);

                string formatedDateTime = date.ToString(outputFormat);
                return Convert.ToDateTime(formatedDateTime);   
            }
//Calling

    string oFormat = "yyyy-MM-dd HH:mm:ss";
    DateTime requiredDT = ConvertPlainStringToDatetime("20190205","yyyyMMddHHmmss", oFormat  );
    DateTime requiredDT = ConvertPlainStringToDatetime("20190508-12:46:42","yyyyMMdd-HH:mm:ss", oFormat);

-1

グーグル検索に何時間も費やした後、私はローカルで日付時刻を与えたときに以下の解決策を見つけました、他のサーバーから例外はありませんでしたが、エラーがありました.........日付が適切な形式ではありません。 C#でテキストボックスの日付時刻を保存/検索する前に、外側のSererカルチャがデータベースサーバーカルチャと同じかどうかを確認するだけです。Exは両方とも "en-US"であるか、スナップショットの下で両方とも "en-GB"である必要があります。

ここに画像の説明を入力してください

(dd / mm / yyyy)や(yyyy / mm / dd)などの異なる日付形式でも、正確に保存または検索されます。


それらのmを大文字にする必要があります-Mは月、mは分です。これにより、たとえば2017/51/10
Chris Moschiniが2017年

日付のフォーマットを表示するだけで、日/月/年または年/月/日..........文化の違いにもかかわらず検索されます...時間と混同しないでください....... .........この形式は、dateTimePickerカレンダーで設定できます........
Abdul Khaliq
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.