在C#編程過程中,通過String類的Length屬性可以獲取對應字符串的長度,但是細心的讀者可能注意到了,String類的Length屬性返回的是字符串中Char對象的個數,也就是說,一個漢字的長度為1,對此,MSDN的解釋如下:
Length 屬性返回此實例中 Char 對象的個數,而不是 Unicode 字符個數。原因在于一個 Unicode 字符可能會用多個 Char 表示。使用 System.Globalization..::.StringInfo 類來處理每個 Unicode 字符而不是每個 Char。
然而,有很多時候我們都需要讓漢字的返回長度為2,特別是以文本文件輸出程序運算的結果時,將漢字的寬度等價于兩個字符的寬度計算,才能得到良好的布局排列。在這種情況下,我們就不能簡單的使用String類的Length屬性了,那么我們又該如何處理呢?網上搜集了兩種解決方法,下面分別進行說明:
方案1:通過對每個字符的byte進行判斷
///
/// 得到字符串的長度,一個漢字算2個字符
///
/// 字符串
/// 返回字符串長度
public static int GetLength(string str) {
if (str.Length == 0) return 0;
ASCIIEncoding ascii = new ASCIIEncoding();
int tempLen = 0;
byte[] s = ascii.GetBytes(str);
for (int i = 0; i < s.Length; i++) {
if ((int)s[i] == 63) {
tempLen += 2;
} else {
tempLen += 1;
}
}
return tempLen;
}
方案2:使用Encoding.Default.GetBytes方法
string str = "hello,統計字符長度";
int length = Encoding.Default.GetByteCount(str);
讀者可以從中選擇自己喜好的方案應用到自己的項目中,還有其它方法,歡迎在留言區域進行討論。
【發表評論0條 】