.NET Core C#中級篇2-5 常見實用類

WarrenRyan發表於2019-08-25

.NETCore CSharp 中級篇2-5

本節內容為常見實用類和方法的使用

String.Format

string.format方法是一個字串格式化類,它裡面的一些寫法是對字串進行指定格式的轉換。

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 例項的值的文字等效項。

看起來挺抽象的,事實上string.format的寫法有點類似於我們的正規表示式。我們著重的講一下幾個非常常用的用法。

數值格式化

字元 說明 示例 輸出
C 貨幣格式化,後接數字為小數點位數 string.Format("{0:C3}", 2) 獲得當前設定的貨幣格式,例如$2.000或¥2.000
D 十進位制,後接數字為向前填充0至N位 string.Format("{0:D3}", 2) 002
X 輸出對應的十六進位制 string.Format("{0:X000}", 12) C
G 常規輸出 string.Format("{0:G}", 2) 2
N 用分號隔開的數字 string.Format("{0:N}", 250000) 250,000.00
自定義 自定義輸出 string.Format("{0:000.000}", 12.2) 012.200

值得注意的是,大括號括起來的是一個佔位符,{0:}表示的是後接引數的第一個,{1:}則是第二個,作為一個佔位符存在。

佔位符

佔位符分為以下兩種:

  • 零佔位符0:如果格式化的值在格式字串中出現“0”的位置有一個數字,則此數字被複制到結果字串中。小數點前最左邊的“0”的位置和小數點後最右邊的“0”的位置確定總在結果字串中出現的數字範圍。
    “00”說明符使得值被舍入到小數點前最近的數字,其中零位總被捨去。

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

PS:空格佔位符

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

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

時間格式化

格式化時間非常簡單,我們通常描述時間都是年-月-日 時:分:秒就夠了,在String.Format類中,我們取這些描述詞的英文首字母作為格式化字元,例如1999-05-06我需要轉換成國外常見的時間表達方式05/06/99,我們只需要

"1999-05-06".Format("mm/dd/yy");

非常的簡單。我們列舉出一個表格詳細的闡明常用時間格式化的字元

字元 說明 詳情
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”。
t 短時間模式 表示由當前 ShortTimePattern 屬性定義的自定義 DateTime 格式字串。例如,用於固定區域性的自定義格式字串為“HH:mm”。
T 長時間模式 表示由當前 LongTimePattern 屬性定義的自定義 DateTime 格式字串。例如,用於固定區域性的自定義格式字串為“HH:mm:ss”。
Y 或 y 年月模式 表示由當前 YearMonthPattern 屬性定義的自定義 DateTime 格式字串。例如,用於固定區域性的自定義格式字串為“yyyy MMMM”。

還有一些自定義的方法,例如我之前舉的例子

字元 說明 詳情
N個d 將月中日期表示為從 1 至 31 的數字。 N個d則是在時間有效位小於N時在前面加0
N個M 將月表示為從 1 至 12 的數字。 N個d則是在時間有效位小於N時在前面加0
N個y 表示年 N個y則是在時間有效位小於N時在前面加0,特別的,1個y也是使用年份後兩位進行表示。
N個s 將秒錶示為從 0 至 59 的數字。 秒錶示自前一分鐘後經過的整秒數
N個m 將分表示為從 0 至 59 的數字。 分鐘表示自前一小時後經過的整分鐘數
N個h 將時表示為從 0 至 12 的數字。 自午夜或中午開始對整小時計數
N個H 將時表示為從 0 至 24 的數字。 自午夜或中午開始對整小時計數

列舉格式字串

字元 說明
G 或 g 如有可能,將列舉項顯示為字串值,否則顯示當前例項的整數值。如果列舉定義中設定了 Flags 屬性,則串聯每個有效項的字串值並將各值用逗號分開。如果未設定 Flags 屬性,則將無效值顯示為數字項。
F 或 f 如有可能,將列舉項顯示為字串值。如果值可以完全顯示為列舉項的總和(即使未提供 Flags 屬性),則串聯每個有效項的字串值並將各值用逗號分開。如果值不能完全由列舉項確定,則將值格式化為整數值。
D 或 d 以儘可能短的表示形式將列舉項顯示為整數值。
X 或 x 將列舉項顯示為十六進位制值。按需要將值表示為帶有前導零,以確保值的長度最少有八位

DateTime

DateTime是C#時間處理的大殺器,它的效率非常高,顯著的優於其他語言的時間處理,其中DateTime型別重寫了ToString()方法,在DateTime的ToString方法裡面,我們可以輕而易舉的使用我們的格式化字元對它進行格式化。

事實上DateTime結構並不是我們今天講的主題,因為DateTime的操作事實上就是我們的string.Format操作,至多我們講一下DateTime和字串的轉換

符合時間格式的字串轉換成DateTime結構只需要使用

DateTime.Parse(str);

我們這節主要講解的是TimeSpan時間計算類的使用,不過在DateTime中也有部分函式用於時間計算,例如

  • Add 將指定的TimeSpan的值加到此例項的值上。
  • AddDays 將指定的天數加到此例項的值上。
  • AddHours 將指定的小時數加到此例項的值上。
  • AddMilliseconds 將指定的毫秒數加到此例項的值上。
  • AddMinutes 將指定的分鐘數加到此例項的值上。
  • AddMonths 將指定的月份數加到此例項的值上。
  • AddSeconds 將指定的秒數加到此例項的值上。
  • AddYears 將指定的年份數加到此例項的值上。
  • Subtract 從此例項中減去指定的時間或持續時間。

TimeSpan

下面的列表闡明瞭部分TimeSpan的方法

  • Add:與另一個TimeSpan值相加。
  • Days:返回用天數計算的TimeSpan值。
  • Hours:返回用小時計算的TimeSpan值
  • Milliseconds:返回用毫秒計算的TimeSpan值。
  • Minutes:返回用分鐘計算的TimeSpan值。
  • Negate:返回當前例項的相反數。
  • Seconds:返回用秒計算的TimeSpan值。
  • Subtract:從中減去另一個TimeSpan值。
  • Ticks:返回TimeSpan值的tick數。
  • TotalDays:返回TimeSpan值表示的天數。
  • TotalHours:返回TimeSpan值表示的小時數。
  • TotalMilliseconds:返回TimeSpan值表示的毫秒數。
  • TotalMinutes:返回TimeSpan值表示的分鐘數。
  • TotalSeconds:返回TimeSpan值表示的秒數。

StringBuilder

String物件是不可改變的,每次使用System.String類中的方法之一時,都要在記憶體中建立一個新的字串物件,這就需要為該新物件分配新的空間。如果你需要經常操作字串物件的話,直接使用string進行加減運算是很不划算的做法,這個時候,我們需要使用我們的StringBuilder類進行操作。

StringBuilder可以自由擴充套件大小,因為StringBuilder分配在堆區。

並且StringBuilder可以指定其大小,當指定分配大小之後,效能就會得到提升。在達到容量之前,它不會為其自己重新分配空間。如果超過指定大小系統會當前大小倍增,也就10,15,20。建議指定大小。

常用的幾個方法

  • StringBuilder.Append //將資訊追加到當前StringBuilder的結尾。
  • StringBuilder.AppendFormat //用帶格式文字替換字串中傳遞的格式說明符。
  • StringBuilder.Insert //將字串或物件插入到當前StringBuilder物件的指定索引處。
  • StringBuilder.Remove //從當前StringBuilder物件中移除指定數量的字元。
  • StringBuilder.Replace //替換指定索引處的指定字元。

值得注意的一件事情是,對於C#,微軟對於String型別有著特殊的最佳化,如果兩個字串內容相同,那麼他們只會被建立一次,也就是說會指向同一塊記憶體地址,並且,C#比較的方法有以下三種

  • ==它是比較的棧裡面的值是否相等(值比較)
  • Equals它比較的是堆裡面的值是否相等(引用地址值比較)
  • Object.ReferenceEquals(obj1,obj2)它是比較的是記憶體地址是否相等

示例:

StringBuilder MyStringBuilder = new StringBuilder("Hello   World!",30);  
MyStringBuilder.Insert(6,"test");
MyStringBuilder.Append("test");

你只需要記住,在面對大量字串的操作處理中,我們使用StringBuilder來提高我們的運算速度。

如果我的文章幫助了您,請您在github.NETCoreGuide專案幫我點一個star,在部落格園中點一個關注和推薦。

Github

BiliBili主頁

WarrenRyan'sBlog

部落格園

相關文章