一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - ASP.NET教程 - asp.net中C#獲取字符串中漢字的個(gè)數(shù)的具體實(shí)現(xiàn)方法

asp.net中C#獲取字符串中漢字的個(gè)數(shù)的具體實(shí)現(xiàn)方法

2019-12-01 11:58ASP.NET教程網(wǎng) ASP.NET教程

獲取字符串中漢字原理是判斷漢字編碼然后進(jìn)行判斷是漢字還是數(shù)字了,還有就是利用正則表達(dá)式,同樣是以漢字ascii為標(biāo)準(zhǔn)來(lái)獲取

符串可以包括數(shù)字,字母,漢字或者其他的字符。使用Char類型的IsDigit靜態(tài)方法可以判斷字符串中的字符是否為數(shù)字,使用Char類型中的IsLetter靜態(tài)方法可以判斷字符串中是否為字母。我們來(lái)實(shí)現(xiàn)一種方法來(lái)實(shí)現(xiàn)判斷字符串中是否為漢字,通過(guò)此方法可以計(jì)算字符串中漢字的個(gè)數(shù):

 

首先根據(jù)效果圖設(shè)置好Form的界面和內(nèi)容,Box1.Text為輸入的字符串,我們對(duì)該字符串的處理,來(lái)計(jì)算漢字的個(gè)數(shù),雙擊Buton控件,編輯其單擊事件代碼。

我們看下漢字的Unicode范圍,普遍給出了0x4E00到0x9FA5,只要我們接受到的字符的16進(jìn)制編碼在此范圍,我們就認(rèn)為此字符為漢字(label4.Text顯示漢字的個(gè)數(shù))

 

復(fù)制代碼代碼如下:

string a=Box1.Text;
int K = 0;
for (int i = 0; i < a.Length;i++ )
{
char j=a[i];
ushort s = j;
if (s >= 0x4E00&&s<=0x9FA5)
{
K++;
}
label4.Text = “” + K;

 

后再再整理了一些函數(shù) C#中使用正則表達(dá)式來(lái)從字符串中判斷出漢字

 

復(fù)制代碼代碼如下:


//首先引用命名空間
using System.Text.RegularExpressions;

 

//定義一個(gè)函數(shù),返回字符串中的漢字個(gè)數(shù)
public static int GetHanNumFromString(string str)
{
    int count = 0;
    Regex regex = new Regex(@"^[u4E00-u9FA5]{0,}$");

    for (int i = 0; i < str.Length; i++)
    {
        if (regex.IsMatch(str[i].ToString()))
        {
            count++;
        }
    }

    return count;
}

 

 

代碼說(shuō)明:

1、Unicode字符的u4E00到u9FA5之間為漢字編碼,所以使用它來(lái)表示漢字的正則匹配范圍。
2、字符串可以直接進(jìn)行索引,索引得到的值的數(shù)據(jù)類型為char,所以str[i].ToString()是為了把char再度轉(zhuǎn)換為字符串。
3、使用Regex的IsMatch方法,可以判斷字符串是否與給定的正則表達(dá)式匹配,如果匹配成功則返回True,否則為False。

例,獲取一個(gè)字符串中的漢字的個(gè)數(shù) C#獲取字符串全角的個(gè)數(shù)

復(fù)制代碼代碼如下:


static void Main(string[] args)
        {
            while (true)
            {

 

      Console.WriteLine("輸入一串字符");
                string str = Console.ReadLine();//定義一個(gè)變量str用來(lái)存儲(chǔ)輸入的字符串
                int num= Encoding.Default.GetByteCount(str);//Encoding.Default.GetByteCount(str)在系統(tǒng)默認(rèn)下計(jì)算對(duì)字符進(jìn)行編碼是所產(chǎn)生的字節(jié)數(shù)
                int len = str.Length;//獲取字符串的長(zhǎng)度
                Console.WriteLine("有{0}漢字",num-len);//num-len就是字符串中的漢字個(gè)數(shù)          
            }
}

 

例,這個(gè)也是正常的

 

復(fù)制代碼代碼如下:

ArrayList itemList = new ArrayList(); 
CharEnumerator CEnumerator = textBox1.Text.GetEnumerator(); 
Regex regex = new Regex("^[/u4E00-/u9FA5]{0,}$"); 
while (CEnumerator.MoveNext()) 

     if(regex.IsMatch(CEnumerator.Current.ToString(),0)) 
         itemList.Add(CEnumerator.Current.ToString()); 
     textBox2.Text = itemList.Count.ToString(); 
}

 

原理是:獲得字符串中漢字的個(gè)數(shù)時(shí),可以首先定義一個(gè)與漢字相匹配的正則表達(dá)式,然后使用CharEnumerator對(duì)象的MoveNext方法循環(huán)訪問(wèn)字符串中的每個(gè)字符,如果訪問(wèn)的字符與定義的正則表達(dá)式相匹配,則將其添加到一個(gè)數(shù)組中,最后獲得該數(shù)組的項(xiàng)數(shù)即為字符串中漢字的個(gè)數(shù)。獲得字符串中漢字個(gè)數(shù).

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品AV亚洲乱码一区二区 | 青青草成人在线 | 波多野结衣之双方调教在线观看 | 欧美久久久久久久一区二区三区 | 日韩毛片免费线上观看 | 国产在线伊人 | 欧美视频一区二区专区 | 911爱豆传媒国产 | 精品国产免费第一区二区三区日韩 | 色多多在线视频 | 日韩精品亚洲专区在线影视 | 国产精品欧美一区二区 | 大学生特黄特色大片免费播放 | 明星乱淫 | 九九九九九九 | 114级毛片免费观看 1024亚洲天堂 | 国内精品视频免费观看 | 欧美sq| 国产综合图区 | 精品久久久久久久久久久久久久久 | 日韩精品亚洲一级在线观看 | 国产麻豆视频 | 精品亚洲永久免费精品 | 91综合精品网站久久 | 日韩黄色影视 | 18未年禁止免费观看 | 久久不射网| 国产性tv国产精品 | 久久综合香蕉久久久久久久 | 激情三级做爰在线观看激情 | 深夜福利免费观看 | 国产日韩精品欧美一区 | www久久精品| 日本小视频免费 | 女同性互吃奶乳免费视频 | 国产一级毛片国语版 | 不知火舞被c视频在线播放 不卡一区二区三区卡 | 暖暖 免费 高清 中文 日本 | 无遮免费网站在线入口 | 色噜噜视频影院 | 国内精品久久久久小说网 |