最近做一個小功能,要判斷傳入字串是否含有中文,再作後續的動作。這邊記錄判斷邏輯的寫法,程式的邏輯為當傳入參數只要是字串中有任何一個中文字都會回傳True。
要多考慮中文的Unicode範圍Unicode字元範圍
- 3400~4DFFh:中日韓認同表意文字擴充A區,總計收容6,582個中日韓漢字
- 4E00~9FFFh:中日韓認同表意文字區,總計收容20,902個中日韓漢字。
- A000~A4FFh:彝族文字區,收容中國南方彝族文字和字根。
- AC00~D7FFh:韓文拼音組合字區,收容以韓文音符拼成的文字。
- F900~FAFFh:中日韓兼容表意文字區,總計收容302個中日韓漢字。
- FB00~FFFDh:文字表現形式區,收容組合拉丁文字、希伯來文、阿拉伯文、中日韓直式標點、小符號、半角符號、全角符號等。
程式碼
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
| public static bool isChinese(string strChinese) { bool bresult = true; int dRange = 0; int dstringmax=Convert.ToInt32("9fff", 16); int dstringmin=Convert.ToInt32("4e00", 16); for (int i = 0; i < strChinese.Length; i++) { dRange = Convert.ToInt32(Convert.ToChar(strChinese.Substring(i, 1))); if (dRange >= dstringmin && dRange <dstringmax ) { bresult = true; break; } else { bresult = false; } } return bresult; }
|
要考慮到unicode範圍才會正確