搜尋此網誌

2014年10月20日 星期一

判斷字串中是否有中文字

Demo Code Ver. :.NET Framework 4.0

最近做一個小功能,要判斷傳入字串是否含有中文,再作後續的動作。這邊記錄判斷邏輯的寫法,程式的邏輯

為當傳入參數只要是字串中有任何一個中文字都會回傳True

謝謝Allen kuo指正,小弟這邊有一個地方沒有考慮到,應該還要多考慮一個中文的Unicode範圍,這樣才會精準

Unicode字元範圍

3400~4DFFh:中日韓認同表意文字擴充A區,總計收容6,582個中日韓漢字。
4E00~9FFFh:中日韓認同表意文字區,總計收容20,902個中日韓漢字。
A000~A4FFh:彝族文字區,收容中國南方彝族文字和字根。
AC00~D7FFh:韓文拼音組合字區,收容以韓文音符拼成的文字。
F900~FAFFh:中日韓兼容表意文字區,總計收容302個中日韓漢字。
FB00~FFFDh:文字表現形式區,收容組合拉丁文字、希伯來文、阿拉伯文、中日韓直式標點、小符號、半角符號、全角符號等。

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;
}

驗證結果程式

Console.WriteLine(isChinese("中文").ToString());
Console.WriteLine(isChinese("Chinese").ToString());

Console.WriteLine(isChinese("AA中").ToString());



必須要考慮到unicode範圍才會正確





沒有留言:

張貼留言