佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > asp.net中C#獲取字符串中漢字的個數(shù)的具體實現(xiàn)方法

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

熱門標(biāo)簽:電商新玩法 客戶服務(wù) 電銷業(yè)務(wù) 科大訊飛語音識別系統(tǒng) 人工智能 百度AI接口 國美全國運(yùn)營中心 網(wǎng)站排名優(yōu)化

符串可以包括數(shù)字,字母,漢字或者其他的字符。使用Char類型的IsDigit靜態(tài)方法可以判斷字符串中的字符是否為數(shù)字,使用Char類型中的IsLetter靜態(tài)方法可以判斷字符串中是否為字母。我們來實現(xiàn)一種方法來實現(xiàn)判斷字符串中是否為漢字,通過此方法可以計算字符串中漢字的個數(shù),運(yùn)行效果如圖:

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

我們看下漢字的Unicode范圍,普遍給出了0x4E00到0x9FA5,只要我們接受到的字符的16進(jìn)制編碼在此范圍,我們就認(rèn)為此字符為漢字(label4.Text顯示漢字的個數(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 >= 0x4E00s=0x9FA5)
{
K++;
}
label4.Text = “” + K;

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

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

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

//定義一個函數(shù),返回字符串中的漢字個數(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;
}

代碼說明:

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

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

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

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

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

例,這個也是正常的

復(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();
}

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

您可能感興趣的文章:
  • asp.net中利用正則表達(dá)式判斷一個字符串是否為數(shù)字的代碼
  • ASP.NET 字符串截取
  • 在asp.NET中字符串替換的五種方法
  • asp.net 字符串、二進(jìn)制、編碼數(shù)組轉(zhuǎn)換函數(shù)
  • asp.net 字符串加密解密技術(shù)
  • asp.net 關(guān)于字符串內(nèi)范圍截取的一點方法總結(jié)
  • Asp.net 字符串操作基類(安全,替換,分解等)
  • ASP.NET Core自定義本地化教程之從文本文件讀取本地化字符串

標(biāo)簽:咸寧 拉薩 益陽 攀枝花 南平 棗莊 POS機(jī) 廈門

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net中C#獲取字符串中漢字的個數(shù)的具體實現(xiàn)方法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    马鞍山市| 桐城市| 紫阳县| 五寨县| 仙游县| 鲁山县| 富锦市| 罗城| 九龙城区| 苗栗县| 松潘县| 卓资县| 吐鲁番市| 灵川县| 高平市| 甘洛县| 蒙城县| 鲁山县| 福泉市| 柳河县| 中牟县| 天峨县| 海城市| 会昌县| 祁阳县| 新邵县| 临夏县| 伊宁县| 周至县| 连州市| 吉水县| 东台市| 定陶县| 黄骅市| 什邡市| 抚远县| 盐津县| 承德县| 邓州市| 五台县| 十堰市|