【轉】string.Format對C#字串格式化

來源:互聯網
上載者:User

標籤:

【轉】http://blog.csdn.net/samsone/article/details/7556781

1、格式化貨幣(跟系統的環境有關,中文系統預設格式化人民幣,英文系統格式化美元)

string.Format("{0:C}",0.2) 結果為:¥0.20 (英文作業系統結果:$0.20)

預設格式化小數點後面保留兩位小數,如果需要保留一位或者更多,可以指定位元
string.Format("{0:C1}",23.15) 結果為:¥23.2 (截取會自動四捨五入)

格式化多個Object執行個體
string.Format("市場價:{0:C},優惠價{1:C}",23.15,19.82)

2、格式化十進位的數字(格式化成固定的位元,位元不能少於未格式化前,只支援整形)

string.Format("{0:D3}",23) 結果為:023

string.Format("{0:D2}",1223) 結果為:1223,(有效位數規範指示結果字串中所需的最少數字個數。)

3、用分號隔開的數字,並指定小數點後的位元

string.Format("{0:N}", 14200) 結果為:14,200.00 (預設為小數點後面兩位)

string.Format("{0:N3}", 14200.2458) 結果為:14,200.246 (自動四捨五入)

4、格式化百分比

string.Format("{0:P}", 0.24583) 結果為:24.58% (預設保留百分的兩位小數)

string.Format("{0:P1}", 0.24583) 結果為:24.6% (自動四捨五入)

5、零預留位置和數字預留位置

string.Format("{0:0000.00}", 12394.039) 結果為:12394.04

string.Format("{0:0000.00}", 194.039) 結果為:0194.04

string.Format("{0:###.##}", 12394.039) 結果為:12394.04

string.Format("{0:####.#}", 194.039) 結果為:194

下面的這段說明比較難理解,多測試一下實際的應用就可以明白了。
零預留位置:
如果格式化的值在格式字串中出現“0”的位置有一個數字,則此數字被複製到結果字串中。小數點前最左邊的“0”的位置和小數點後最右邊的“0”的位置確定總在結果字串中出現的數字範圍。
“00”說明符使得值被舍入到小數點前最近的數字,其中零位總被捨去。

數字預留位置:
如果格式化的值在格式字串中出現“#”的位置有一個數字,則此數字被複製到結果字串中。否則,結果字串中的此位置不儲存任何值。 
請注意,如果“0”不是有效數字,此說明符永不顯示“0”字元,即使“0”是字串中唯一的數字。如果“0”是所顯示的數字中的有效數字,則顯示“0”字元。 
“##”格式字串使得值被舍入到小數點前最近的數字,其中零總被捨去。

PS:空格預留位置

string.Format("{0,-50}", theObj);//格式化成50個字元,原字元靠左對齊,不足則補空格
string.Format("{0,50}", theObj);//格式化成50個字元,原字元靠右對齊,不足則補空格

6、日期格式化

string.Format("{0:d}",System.DateTime.Now) 結果為:2009-3-20 (月份位置不是03)

string.Format("{0:D}",System.DateTime.Now) 結果為:2009年3月20日

string.Format("{0:f}",System.DateTime.Now) 結果為:2009年3月20日 15:37

string.Format("{0:F}",System.DateTime.Now) 結果為:2009年3月20日 15:37:52

string.Format("{0:g}",System.DateTime.Now) 結果為:2009-3-20 15:38

string.Format("{0:G}",System.DateTime.Now) 結果為:2009-3-20 15:39:27

string.Format("{0:m}",System.DateTime.Now) 結果為:3月20日

string.Format("{0:t}",System.DateTime.Now) 結果為:15:41

string.Format("{0:T}",System.DateTime.Now) 結果為:15:41:50


更詳細的說明請下面微軟對此的說明或者上msdn上查詢。

微軟MSDN對string.format的方法說明:

名稱 說明 
String.Format (String, Object) 將指定的 String 中的格式項替換為指定的 Object 執行個體的值的文本等效項。 
String.Format (String, Object[]) 將指定 String 中的格式項替換為指定數組中相應 Object 執行個體的值的文本等效項。 
String.Format (IFormatProvider, String, Object[]) 將指定 String 中的格式項替換為指定數組中相應 Object 執行個體的值的文本等效項。指定的參數提供地區性特定的格式設定資訊。 
String.Format (String, Object, Object) 將指定的 String 中的格式項替換為兩個指定的 Object 執行個體的值的文本等效項。 
String.Format (String, Object, Object, Object) 將指定的 String 中的格式項替換為三個指定的 Object 執行個體的值的文本等效項。

標準數字格式字串

格式說明符 名稱 說明 
C 或 c
貨幣
數字轉換為表示貨幣金額的字串。轉換由當前 NumberFormatInfo 對象的貨幣格式資訊控制。

有效位數規範指示所需的小數位元。如果省略有效位數規範,則使用當前 NumberFormatInfo 對象給定的預設貨幣精度。

D 或 d
十進位數
只有整型才支援此格式。數字轉換為十進位數字 (0-9) 的字串,如果數字為負,則前面加負號。

有效位數規範指示結果字串中所需的最少數字個數。如果需要的話,則用零填充該數位左側,以產生有效位數規範給定的數字個數。

E 或 e
科學記號標記法(指數)
數字轉換為“-d.ddd…E+ddd”或“-d.ddd…e+ddd”形式的字串,其中每個“d”表示一個數字 (0-9)。如果該數字為負,則該字串以減號開頭。小數點前總有一個數字。

有效位數規範指示小數點後所需的位元。如果省略有效位數規範,則使用預設值,即小數點後六位元字。

格式說明符的大小寫指示在指數前加首碼“E”還是“e”。指數總是由正號或負號以及最少三位元字組成。如果需要,用零填充指數以滿足最少三位元字的要求。

F 或 f
定點
數字轉換為“-ddd.ddd…”形式的字串,其中每個“d”表示一個數字 (0-9)。如果該數字為負,則該字串以減號開頭。

有效位數規範指示所需的小數位元。如果忽略有效位數規範,則使用當前 NumberFormatInfo 對象給定的預設數值精度。

G 或 g
常規
根據數字類型以及是否存在有效位數規範,數字會轉換為定點或科學記號標記法的最緊湊形式。如果有效位數規範被省略或為零,則數位類型決定預設精度,如下表所示。

Byte 或 SByte:3

Int16 或 UInt16:5

Int32 或 UInt32:10

Int64 或 UInt64:19

Single:7

Double:15

Decimal:29

如果用科學記號標記法表示數字時指數大於 -5 而且小於有效位數規範,則使用定點標記法;否則使用科學記號標記法。如果要求有小數點,並且忽略尾部零,則結果包含小數點。如果有效位數規範存在,並且結果的有效數字位元超過指定精度,則通過舍入刪除多餘的尾部數字。

上述規則有一個例外:如果數字是 Decimal 而且省略有效位數規範時。在這種情況下總使用定點標記法並保留尾部零。

使用科學記號標記法時,如果格式說明符是“G”,結果的指數帶首碼“E”;如果格式說明符是“g”,結果的指數帶首碼“e”。 

N 或 n
數字
數字轉換為“-d,ddd,ddd.ddd…”形式的字串,其中“-”表示負數符號(如果需要),“d”表示數字 (0-9),“,”表示數字組之間的千位分隔字元,“.”表示小數點符號。實際的負數模式、數字組大小、千位分隔字元以及十進位分隔字元由當前 NumberFormatInfo 對象指定。

有效位數規範指示所需的小數位元。如果忽略有效位數規範,則使用當前 NumberFormatInfo 對象給定的預設數值精度。

P 或 p
百分比
數字轉換為由 NumberFormatInfo.PercentNegativePattern 或 NumberFormatInfo.PercentPositivePattern 屬性定義的、表示百分比的字串,前者用於數字為負的情況,後者用於數字為正的情況。已轉換的數字乘以 100 以表示為百分比。

有效位數規範指示所需的小數位元。如果忽略有效位數規範,則使用當前 NumberFormatInfo 對象給定的預設數值精度。

R 或 r
往返過程
只有 Single 和 Double 類型支援此格式。往返過程說明符保證轉換為字串的數值再次被分析為相同的數值。使用此說明符格式化數值時,首先使用常規格式對其進行測試:Double 使用 15 位精度,Single 使用 7 位精度。如果此值被成功地分析回相同的數值,則使用常規格式說明符對其進行格式化。但是,如果此值未被成功地分析為相同數值,則它這樣格式化:Double 使用 17 位精度,Single 使用 9 位精度。

雖然此處可以存在有效位數規範,但它將被忽略。使用此說明符時,往返過程優先於精度。 

X 或 x
十六進位數
只有整型才支援此格式。數字轉換為十六進位數位字串。格式說明符的大小寫指示對大於 9 的十六進位數字使用大寫字元還是小寫字元。例如,使用“X”產生“ABCDEF”,使用“x”產生“abcdef”。

有效位數規範指示結果字串中所需的最少數字個數。如果需要的話,則用零填充該數位左側,以產生有效位數規範給定的數字個數。 

任何其他單個字元
(未知說明符)
(未知說明符將引發運行庫格式異常。)


自訂數字格式字串

格式說明符 名稱 說明 
0
零預留位置
如果格式化的值在格式字串中出現“0”的位置有一個數字,則此數字被複製到結果字串中。小數點前最左邊的“0”的位置和小數點後最右邊的“0”的位置確定總在結果字串中出現的數字範圍。

“00”說明符使得值被舍入到小數點前最近的數字,其中零位總被捨去。例如,用“00”格式化 34.5 將得到值 35。

#
數字預留位置
如果格式化的值在格式字串中出現“#”的位置有一個數字,則此數字被複製到結果字串中。否則,結果字串中的此位置不儲存任何值。

請注意,如果“0”不是有效數字,此說明符永不顯示“0”字元,即使“0”是字串中唯一的數字。如果“0”是所顯示的數字中的有效數字,則顯示“0”字元。

“##”格式字串使得值被舍入到小數點前最近的數字,其中零總被捨去。例如,用“##”格式化 34.5 將得到值 35。

.
小數點
格式字串中的第一個“.”字元確定格式化的值中的小數點分隔字元的位置;任何其他“.”字元被忽略。

用作小數點分隔字元的實際字元由控制格式化的 NumberFormatInfo 的 NumberDecimalSeparator 屬性確定。

,
千位分隔字元和數字比例換算
“,”字元可作為千位分隔字元說明符和數字比例換算說明符。

千位分隔字元說明符:如果在兩個數字預留位置(0 或 #)之間指定一個或多個“,”字元用於設定數字整數位的格式,則在輸出的整數部分中每個數字組之間插入一個組分隔字元字元。

當前 NumberFormatInfo 對象的 NumberGroupSeparator 和 NumberGroupSizes 屬性將確定用作數字組分隔字元的字元以及每個數字組的大小。例如,如果使用字串“#,#”和固定地區性對數字 1000 進行格式化,則輸出為“1,000”。

數字比例換算說明符:如果在緊鄰顯式或隱式小數點的左側指定一個或多個“,”字元,則每出現一個數字比例換算說明符便將要格式化的數字除以 1000。例如,如果使用字串“0,,”對數字 1000000000 進行格式化,則輸出為“100”。

可以在同一格式字串中使用千位分隔字元說明符和數字比例換算說明符。例如,如果使用字串“#,0,,”和固定地區性對數字 10000000000 進行格式化,則輸出為“1,000”。 

%
百分比預留位置
在格式字串中出現“%”字元將導致數字在格式化之前乘以 100。適當的符號插入到數字本身在格式字串中出現“%”的位置。使用的百分比字元由當前的 NumberFormatInfo 類確定。

E0

E+0

E-0

e0

e+0

e-0
科學記號標記法
如果“E”、“E+”、“E-”、“e”、“e+”或“e-”中的任何一個字串出現在格式字串中,而且後面緊跟至少一個“0”字元,則數字用科學記號標記法來格式化,在數字和指數之間插入“E”或“e”。跟在科學記號標記法指示符後面的“0”字元數確定指數輸出的最小位元。“E+”和“e+”格式指示符號字元(正號或負號)應總是置於指數前面。“E”、“E-”、“e”或“e-”格式指示符號字元僅置於負指數前面。

\
轉義符
在 C# 和 C++ 中,反斜線字元使格式字串中的下一個字元被解釋為逸出序列。它與傳統的格式化序列一起使用,如“\n”(換行)。

在某些語言中,轉義符本身用作文本時必須跟在轉義符之後。否則,編譯器將該字元理解為轉義符。使用字串“\\”顯示“\”。

請注意,Visual Basic 中不支援此轉義符,但是 ControlChars 提供相同的功能。

’ABC’

"ABC"
字串
引在單引號或雙引號中的字元被複製到結果字串中,而且不影響格式化。

;
部分分隔字元
“;”字元用於分隔格式字串中的正數、負數和零各部分。

其他
所有其他字元
所有其他字元被複製到結果字串中,而且不影響格式化。


標準 DateTime 格式字串

格式說明符 名稱 說明 
d
短日期模式
表示由當前 ShortDatePattern 屬性定義的自訂 DateTime 格式字串。

例如,用於固定地區性的自訂格式字串為“MM/dd/yyyy”。

D
長日期模式
表示由當前 LongDatePattern 屬性定義的自訂 DateTime 格式字串。

例如,用於固定地區性的自訂格式字串為“dddd, dd MMMM yyyy”。

f
完整日期/時間模式(短時間)
表示長日期 (D) 和短時間 (t) 模式的組合,由空格分隔。

F
完整日期/時間模式(長時間)
表示由當前 FullDateTimePattern 屬性定義的自訂 DateTime 格式字串。

例如,用於固定地區性的自訂格式字串為“dddd, dd MMMM yyyy HH:mm:ss”。

g
常規日期/時間模式(短時間)
表示短日期 (d) 和短時間 (t) 模式的組合,由空格分隔。

G
常規日期/時間模式(長時間)
表示短日期 (d) 和長時間 (T) 模式的組合,由空格分隔。

M 或 m
月日模式
表示由當前 MonthDayPattern 屬性定義的自訂 DateTime 格式字串。

例如,用於固定地區性的自訂格式字串為“MMMM dd”。

o
往返日期/時間模式
表示使用保留時區資訊的模式的自訂 DateTime 格式字串。該模式專用於往返 DateTime 格式(包括文本形式的 Kind 屬性)。隨後將 Parse 或 ParseExact 與正確的 Kind 屬性值一起使用可以對格式化的字串進行反向分析。

自訂格式字串為“yyyy‘-‘MM‘-‘dd‘T‘HH‘:‘mm‘:‘ss.fffffffK”。

用於此說明符的模式是定義的標準。因此,無論所使用的地區性或所提供的格式提供者是什麼,它總是相同的。

R 或 r
RFC1123 模式
表示由當前 RFC1123Pattern 屬性定義的自訂 DateTime 格式字串。該模式是定義的標準,並且屬性是唯讀。因此,無論所使用的地區性或所提供的格式提供者是什麼,它總是相同的。

定義格式字串為“ddd, dd MMM yyyy HH‘:‘mm‘:‘ss ‘GMT‘”。

格式化不會修改正在格式化的 DateTime 對象的值。因此,應用程式在使用此格式說明符之前必須將該值轉換為國際標準時間 (UTC)。

s
可排序的日期/時間模式;符合 ISO 8601
表示由當前 SortableDateTimePattern 屬性定義的自訂 DateTime 格式字串。此模式是定義的標準,並且屬性是唯讀。因此,無論所使用的地區性或所提供的格式提供者是什麼,它總是相同的。

自訂格式字串為“yyyy‘-‘MM‘-‘dd‘T‘HH‘:‘mm‘:‘ss”。

t
短時間模式
表示由當前 ShortTimePattern 屬性定義的自訂 DateTime 格式字串。

例如,用於固定地區性的自訂格式字串為“HH:mm”。

T
長時間模式
表示由當前 LongTimePattern 屬性定義的自訂 DateTime 格式字串。

例如,用於固定地區性的自訂格式字串為“HH:mm:ss”。

u
通用的可排序日期/時間模式
表示由當前 UniversalSortableDateTimePattern 屬性定義的自訂 DateTime 格式字串。此模式是定義的標準,並且屬性是唯讀。因此,無論所使用的地區性或所提供的格式提供者是什麼,它總是相同的。

自訂格式字串為“yyyy‘-‘MM‘-‘dd HH‘:‘mm‘:‘ss‘Z‘”。

格式化日期和時間時不進行時區轉換。因此,應用程式在使用此格式說明符之前必須將本地日期和時間轉換為國際標準時間 (UTC)。

U
通用的可排序日期/時間模式
表示由當前 FullDateTimePattern 屬性定義的自訂 DateTime 格式字串。

此模式與完整日期/長時間 (F) 模式相同。但是,格式化將作用於等效於正在格式化的 DateTime 對象的國際標準時間 (UTC)。

Y 或 y
年月模式
表示由當前 YearMonthPattern 屬性定義的自訂 DateTime 格式字串。

例如,用於固定地區性的自訂格式字串為“yyyy MMMM”。

任何其他單個字元
(未知說明符)
未知說明符將引發運行時格式異常。


自訂 DateTime 格式字串

格式說明符 說明 
d
將月中日期表示為從 1 至 31 的數字。一位元字的日期設定為不帶前置字元為零的格式。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

dd
將月中日期表示為從 01 至 31 的數字。一位元字的日期設定為帶前置字元為零的格式。

ddd
將一周中某天的縮寫名稱表示為當前 System.Globalization.DateTimeFormatInfo.AbbreviatedDayNames 屬性中定義的名稱。

dddd(另加任意數量的“d”說明符) 
將一周中某天的全名表示為當前 System.Globalization.DateTimeFormatInfo.DayNames 屬性中定義的名稱。

f
表示秒部分的最高有效位。

請注意,如果“f”格式說明符單獨使用,沒有其他格式說明符,則該說明符被看作是“f”標準 DateTime 格式說明符(完整日期/時間模式)。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

將此格式說明符與 ParseExact 或 TryParseExact 方法一起使用時,所用“f”格式說明符的數目指示要分析的秒部分的最高有效位位元。 

ff
表示秒部分的兩個最高有效位。

fff
表示秒部分的三個最高有效位。

ffff
表示秒部分的四個最高有效位。

fffff
表示秒部分的五個最高有效位。

ffffff
表示秒部分的六個最高有效位。

fffffff
表示秒部分的七個最高有效位。

F
表示秒部分的最高有效位。如果該位為零,則不顯示任何資訊。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

將此格式說明符與 ParseExact 或 TryParseExact 方法一起使用時,所用“F”格式說明符的數目指示要分析的秒部分的最高有效位最大位元。

FF
表示秒部分的兩個最高有效位。但不顯示尾隨零(或兩個零位)。

FFF
表示秒部分的三個最高有效位。但不顯示尾隨零(或三個零位)。

FFFF
表示秒部分的四個最高有效位。但不顯示尾隨零(或四個零位)。

FFFFF
表示秒部分的五個最高有效位。但不顯示尾隨零(或五個零位)。

FFFFFF
表示秒部分的六個最高有效位。但不顯示尾隨零(或六個零位)。

FFFFFFF
表示秒部分的七個最高有效位。但不顯示尾隨零(或七個零位)。

g 或 gg(另加任意數量的“g”說明符) 
表示時期或紀元(例如 A.D.)。如果要設定格式的日期不具有關聯的時期或紀元字串,則忽略該說明符。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

h
將小時表示為從 1 至 12 的數字,即通過 12 小時製表示小時,自午夜或中午開始對整小時計數。因此,午夜後經過的某特定小時數與中午過後的相同小時數無法加以區分。小時數不進行舍入,一位元字的小時數設定為不帶前置字元為零的格式。例如,給定時間為 5:43,則此格式說明符顯示“5”。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

hh, hh(另加任意數量的“h”說明符) 
將小時表示為從 01 至 12 的數字,即通過 12 小時製表示小時,自午夜或中午開始對整小時計數。因此,午夜後經過的某特定小時數與中午過後的相同小時數無法加以區分。小時數不進行舍入,一位元字的小時數設定為帶前置字元為零的格式。例如,給定時間為 5:43,則此格式說明符顯示“05”。

H
將小時表示為從 0 至 23 的數字,即通過從零開始的 24 小時製表示小時,自午夜開始對小時計數。一位元字的小時數設定為不帶前置字元為零的格式。 

HH, HH(另加任意數量的“H”說明符) 
將小時表示為從 00 至 23 的數字,即通過從零開始的 24 小時製表示小時,自午夜開始對小時計數。一位元字的小時數設定為帶前置字元為零的格式。 

K
表示 DateTime.Kind 屬性的不同值,即“Local”、“Utc”或“Unspecified”。此說明符以文本形式迴圈設定 Kind 值並保留時區。如果 Kind 值為“Local”,則此說明符等效於“zzz”說明符,用於顯示本地時間位移量,例如“-07:00”。對於“Utc”類型值,該說明符顯示字元“Z”以表示 UTC 日期。對於“Unspecified”類型值,該說明符等效於“”(無任何內容)。

m
將分鐘錶示為從 0 至 59 的數字。分鐘錶示自前一小時後經過的整分鐘數。一位元字的分鐘數設定為不帶前置字元為零的格式。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

mm, mm(另加任意數量的“m”說明符) 
將分鐘錶示為從 00 至 59 的數字。分鐘錶示自前一小時後經過的整分鐘數。一位元字的分鐘數設定為帶前置字元為零的格式。

M
將月份表示為從 1 至 12 的數字。一位元字的月份設定為不帶前置字元為零的格式。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

MM
將月份表示為從 01 至 12 的數字。一位元字的月份設定為帶前置字元為零的格式。

MMM
將月份的縮寫名稱表示為當前 System.Globalization.DateTimeFormatInfo.AbbreviatedMonthNames 屬性中定義的名稱。

MMMM
將月份的全名表示為當前 System.Globalization.DateTimeFormatInfo.MonthNames 屬性中定義的名稱。

s
將秒錶示為從 0 至 59 的數字。秒錶示自前一分鐘後經過的整秒數。一位元字的秒數設定為不帶前置字元為零的格式。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

ss, ss(另加任意數量的“s”說明符) 
將秒錶示為從 00 至 59 的數字。秒錶示自前一分鐘後經過的整秒數。一位元字的秒數設定為帶前置字元為零的格式。

t
表示當前 System.Globalization.DateTimeFormatInfo.AMDesignator 或 System.Globalization.DateTimeFormatInfo.PMDesignator 屬性中定義的 A.M./P.M. 指示符的第一個字元。如果正在格式化的時間中的小時數小於 12,則使用 A.M. 指示符;否則使用 P.M. 指示符。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

tt, tt(另加任意數量的“t”說明符) 
將 A.M./P.M. 指示符表示為當前 System.Globalization.DateTimeFormatInfo.AMDesignator 或 System.Globalization.DateTimeFormatInfo.PMDesignator 屬性中定義的內容。如果正在格式化的時間中的小時數小於 12,則使用 A.M. 指示符;否則使用 P.M. 指示符。

y
將年份表示為最多兩位元字。如果年份多於兩位元,則結果中僅顯示兩位低位元。如果年份少於兩位元,則該數字設定為不帶前置字元為零的格式。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

yy
將年份表示為兩位元字。如果年份多於兩位元,則結果中僅顯示兩位低位元。如果年份少於兩位元,則用前置字元為零填充該數字使之達到兩位元。

yyy
將年份表示為三位元字。如果年份多於三位元,則結果中僅顯示三位低位元。如果年份少於三位元,則用前置字元為零填充該數字使之達到三位元。

請注意,對於年份可以為五位元的泰國佛曆,此格式說明符將顯示全部五位元。 

yyyy
將年份表示為四位元字。如果年份多於四位元,則結果中僅顯示四位低位元。如果年份少於四位元,則用前置字元為零填充該數字使之達到四位元。

請注意,對於年份可以為五位元的泰國佛曆,此格式說明符將呈現全部五位元。 

yyyyy(另加任意數量的“y”說明符)
將年份表示為五位元字。如果年份多於五位元,則結果中僅顯示五位低位元。如果年份少於五位元,則用前置字元為零填充該數字使之達到五位元。

如果存在額外的“y”說明符,則用所需個數的前置字元為零填充該數字使之達到“y”說明符的數目。 

z
表示系統時間距格林威治時間 (GMT) 以小時為單位測量的帶符號時區位移量。例如,位於太平洋標準時區中的電腦的位移量為“-8”。

位移量始終顯示為帶有前置字元號。加號 (+) 指示小時數早於 GMT,減號 (-) 指示小時數遲於 GMT。位移量範圍為 –12 至 +13。一位元字的位移量設定為不帶前置字元為零的格式。位移量受夏時制影響。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

zz
表示系統時間距格林威治時間 (GMT) 以小時為單位測量的帶符號時區位移量。例如,位於太平洋標準時區中的電腦的位移量為“-08”。

位移量始終顯示為帶有前置字元號。加號 (+) 指示小時數早於 GMT,減號 (-) 指示小時數遲於 GMT。位移量範圍為 –12 至 +13。一位元字的位移量設定為帶前置字元為零的格式。位移量受夏時制影響。

zzz, zzz(另加任意數量的“z”說明符) 
表示系統時間距格林威治時間 (GMT) 以小時和分鐘為單位測量的帶符號時區位移量。例如,位於太平洋標準時區中的電腦的位移量為“-08:00”。

位移量始終顯示為帶有前置字元號。加號 (+) 指示小時數早於 GMT,減號 (-) 指示小時數遲於 GMT。位移量範圍為 –12 至 +13。一位元字的位移量設定為帶前置字元為零的格式。位移量受夏時制影響。

:
當前 System.Globalization.DateTimeFormatInfo.TimeSeparator 屬性中定義的時間分隔字元,用於區分小時、分鐘和秒。

/
當前 System.Globalization.DateTimeFormatInfo.DateSeparator 屬性中定義的日期分隔符號,用於區分年、月和日。

"
帶引號的字串(引號)。顯示兩個引號 (") 之間的任一字元串的文本值。在每個引號前使用轉義符 (\)。 


帶引號的字串(撇號)。顯示兩個撇號 (‘) 字元之間的任一字元串的文本值。

%c
當自訂 DateTime 格式字串只包含自訂格式說明符“c”時,表示與該自訂格式說明符關聯的結果。也就是說,若要單獨使用自訂格式說明符“d”、“f”、“F”、“h”、“m”、“s”、“t”、“y”、“z”、“H”或“M”,請指定“%d”、“%f”、“%F”、“%h”、“%m”、“%s”、“%t”、“%y”、“%z”、“%H”或“%M”。有關使用單個格式說明符的更多資訊,請參見使用單個自訂格式說明符。

\c
轉義符。當字元“c”前帶有轉義符 (\) 時,將該字元顯示為文本。若要將反斜線字元本身插入結果字串,請使用兩個轉義符(“\\”)。 

任何其他字元 
所有其他字元被複製到結果字串中,而且不影響格式化。


枚舉格式字串

格式字串 結果 
G 或 g
如有可能,將枚舉項顯示為字串值,否則顯示當前執行個體的整數值。如果枚舉定義中設定了 Flags 屬性,則串聯每個有效項的字串值並將各值用逗號分開。如果未設定 Flags 屬性,則將無效值顯示為數字項。

F 或 f
如有可能,將枚舉項顯示為字串值。如果值可以完全顯示為枚舉項的總和(即使未提供 Flags 屬性),則串聯每個有效項的字串值並將各值用逗號分開。如果值不能完全由枚舉項確定,則將值格式化為整數值。

D 或 d
以儘可能短的表示形式將枚舉項顯示為整數值。

X 或 x
將枚舉項顯示為十六進位值。按需要將值表示為帶有前置字元為零,以確保值的長度最少有八位

【轉】string.Format對C#字串格式化

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.