DateTime Formating[轉]

source:http://blog.darkthread.net/blogs/darkthreadtw/archive/2007/04/30/tips-net-datetime-formating.aspxhtml

在VB/VBScript時代,講到日期時間輸出的格式化,你們都知道要用Format(for VB)或FormatDateTime(fro VBScript)。到了.NET時代,有些VB.NET開發者會繼續沿用Format函數。事實上,DateTime Class自己就提供輸出格式化的支援,不用另外呼叫函數處理,並且對C#或VB.NET都通用。ide

以將日期時間轉成字串為例,DateTime.Now.ToString()你們都會,但有個缺點。未指定任何參數的ToString(),輸出的日期時間格式將會依當時Windows的國別設定而定! 這種因地制宜的作法能夠讓Windows Form的User倍感親切,也可算優點,但日期格式的不一致,常會因顯示長度不一形成版面配置的困擾,也是資料庫日期格式轉換出鎚的重要來源。因此我比較習慣應用系統內部使用統一的格式,不要受OS層次響。若是User要作到個人化,再由統一格式轉換過去。我最慣用的格式是"2007/04/30 21:30:00",沒有千禧問題,字串長度永遠固定,24小時制則沒必要在AM/PM vs 上午/下午間掙札,用來最順手。post

不過這個格式並不在.NET預設的標準日期時間格式之列,要產生這個格式,須要本身用yyyy, mm, dd去定義。.NET所提供的客製化日期時間格式字串十分完整,因此用DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")就能夠產生我們要的結果,連string.Format函數都用不到。spa

除了由DateTime -> String的轉換,若要把奇奇怪怪的日期時間字串換回DateTime,.NET也提供了同樣強大的客製彈性! 簡單來說,你能夠怎麼把DateTime轉成String,就能夠再怎麼把String轉成DateTime,只要提供同樣的日期時間格式字串就得了。例如: 
string s="04/30, 2007 @ 09:30"; //某個變態想出來的怪格式
DateTime d=DateTime.ParseExact(s, "MM/dd, yyyy @ HH:mm", null); //照樣解得回來.net

很酷吧!orm

最後補充一點,DateTime.ParseExact的第三個參數是IFormatProvider,在以上的例子中用不到,傳null就能夠了。但若是你有用到AM/PM(中文是上午、下午)、星期、月份全名... 等等各國表示不一樣的資料,IFormatProvider就會有影響。htm

例如: 在中文OS下
DateTime.ParseExact("09:20:00 AM","HH:mm:ss tt", null) 會產生 String was not recognized as a valid DateTime.的訊息。blog

以上的問題出在中文OS的國別設定中預設用中文表示上下午,導致ParseExact看不懂AM/PM。所以我們得改在IFormatProvider傳入使用AM/PM表示上下午的CultureInfo,en-US當然能夠,不過我倒較經常使用InvariantCulture。改寫成如下方式就OK囉!
DateTime.ParseExact("09:20:00 AM","HH:mm:ss tt", System.Globalization.CultureInfo.InvariantCulture)ip

相關文章
相關標籤/搜索