c 中的日期格式轉化

2021-06-07 12:16:31 字數 2930 閱讀 5739

有時候我們要對時間進行轉換,達到不同的顯示效果

預設格式為:2005-6-6 14:33:34

如果要換成成200506,06-2005,2005-6-6或更多的該怎麼辦呢

我們要用到:datetime.tostring的方法(string, iformatprovider)

using system;

using system.globalization;

string format="d";

datetime date=datatime,now;

response.write(date.tostring(format, datetimeformatinfo.invariantinfo));

結果輸出

thursday, june 16, 2005

引數format格式詳細用法

格式字元 關聯屬性/說明

d shortdatepattern

d longdatepattern

f 完整日期和時間(長日期和短時間)

f fulldatetimepattern(長日期和長時間)

g 常規(短日期和短時間)

g 常規(短日期和長時間)

m、m monthdaypattern

r、r rfc1123pattern

s 使用當地時間的 sortabledatetimepattern(基於 iso 8601)

t shorttimepattern

t longtimepattern

u universalsortabledatetimepattern 用於顯示通用時間的格式

u 使用通用時間的完整日期和時間(長日期和長時間)

y、y yearmonthpattern

下表列出了可被合併以構造自定義模式的模式。這些模式是區分大小寫的;例如,識別「mm」,但不識別「mm」。如果自定義模式包含空白字元或用單引號括起來的字元,則輸出字串頁也將包含這些字元。未定義為格式模式的一部分或未定義為格式字元的字元按其原義複製。

格式模式 說明

d 月中的某一天。一位數的日期沒有前導零。

dd 月中的某一天。一位數的日期有乙個前導零。

ddd 週中某天的縮寫名稱,在 abbreviateddaynames 中定義。

dddd 週中某天的完整名稱,在 daynames 中定義。

m 月份數字。一位數的月份沒有前導零。

mm 月份數字。一位數的月份有乙個前導零。

mmm 月份的縮寫名稱,在 abbreviatedmonthnames 中定義。

mmmm 月份的完整名稱,在 monthnames 中定義。

y 不包含紀元的年份。如果不包含紀元的年份小於 10,則顯示不具有前導零的年份。

yy 不包含紀元的年份。如果不包含紀元的年份小於 10,則顯示具有前導零的年份。

yyyy 包括紀元的四位數的年份。

gg 時期或紀元。如果要設定格式的日期不具有關聯的時期或紀元字串,則忽略該模式。

h 12 小時制的小時。一位數的小時數沒有前導零。

hh 12 小時制的小時。一位數的小時數有前導零。

h 24 小時制的小時。一位數的小時數沒有前導零。

hh 24 小時制的小時。一位數的小時數有前導零。

m 分鐘。一位數的分鐘數沒有前導零。

mm 分鐘。一位數的分鐘數有乙個前導零。

s 秒。一位數的秒數沒有前導零。

ss 秒。一位數的秒數有乙個前導零。

f 秒的小數精度為一位。其餘數字被截斷。

ff 秒的小數精度為兩位。其餘數字被截斷。

fff 秒的小數精度為三位。其餘數字被截斷。

ffff 秒的小數精度為四位。其餘數字被截斷。

fffff 秒的小數精度為五位。其餘數字被截斷。

ffffff 秒的小數精度為六位。其餘數字被截斷。

fffffff 秒的小數精度為七位。其餘數字被截斷。

t 在 amdesignator 或 pmdesignator 中定義的 am/pm 指示項的第乙個字元(如果存在)。

tt 在 amdesignator 或 pmdesignator 中定義的 am/pm 指示項(如果存在)。

z 時區偏移量(「+」或「-」後面僅跟小時)。一位數的小時數沒有前導零。例如,太平洋標準時間是「-8」。

zz 時區偏移量(「+」或「-」後面僅跟小時)。一位數的小時數有前導零。例如,太平洋標準時間是「-08」。

zzz 完整時區偏移量(「+」或「-」後面跟有小時和分鐘)。一位數的小時數和分鐘數有前導零。例如,太平洋標準時間是「-08:00」。

: 在 timeseparator 中定義的預設時間分隔符。

/ 在 dateseparator 中定義的預設日期分隔符。

% c 其中 c 是格式模式(如果單獨使用)。如果格式模式與原義字元或其他格式模式合併,則可以省略「%」字元。

\ c 其中 c 是任意字元。照原義顯示字元。若要顯示反斜槓字元,請使用「\\」。

只有上面第二個表中列出的格式模式才能用於建立自定義模式;在第乙個表中列出的標準格式字元不能用於建立自定義模式。自定義模式的長度至少為兩個字元;例如,

datetime.tostring( "d") 返回 datetime 值;「d」是標準短日期模式。

datetime.tostring( "%d") 返回月中的某天;「%d」是自定義模式。

datetime.tostring( "d ") 返回後面跟有乙個空白字元的月中的某天;「d」是自定義模式。

比較方便的是,上面的引數可以隨意組合,並且不會出錯,多試試,肯定會找到你要的時間格式

如要得到2023年06月 這樣格式的時間

可以這樣寫:

date.tostring("yyyy年mm月", datetimeformatinfo.invariantinfo)

如此類推

日期格式轉化

對date的擴充套件,將 date 轉化為指定格式的string 月 m 日 d 12小時 h 24小時 h 分 m 秒 s 周 e 季度 q 可以用 1 2 個佔位符 年 y 可以用 1 4 個佔位符,毫秒 s 只能用 1 個佔位符 是 1 3 位的數字 eg new date pattern y...

SQL日期格式的轉化

在程式編寫時,我會經常會遇到日期格式這個問題,有些地方要2008.11.04,有些地方要用2008 11 04。而有些地方會要20081104這就很煩了。我們總不能為每種變化。都寫乙個方法,其實sql為我們提供轉化的方法。如下 select convert varchar 10 getdate 12...

日期格式轉化小結整理

頁面上顯示的日期格式往往是年月日時分秒的特定格式。而var date new date 獲得出來的是通用時間格式,其中還包含了時區等無用元素。網上搜尋了一段只有轉化年月日時分的函式,我加上秒後,就可以實現將new date 出來的時間格式轉成標準的時間格式。上 var time var format...