国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

asp.net中C#獲取字符串中漢字的個數(shù)實例

2019-11-15 02:31:44
字體:
供稿:網(wǎng)友

asp.net中C#獲取字符串中漢字的個數(shù)實例

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

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

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

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

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

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

//定義一個函數(shù)www.111cn.net ,返回字符串中的漢字個數(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、字符串可以直接進行索引,索引得到的值的數(shù)據(jù)類型為char,所以str[i].ToString()是為了把char再度轉(zhuǎn)換為字符串。3、使用Regex的IsMatch方法,可以判斷字符串是否與給定的正則表達式匹配,如果匹配成功則返回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)默認下計算對字符進行編碼是所產(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ù)時,可以首先定義一個與漢字相匹配的正則表達式,然后使用CharEnumerator對象的MoveNext方法循環(huán)訪問字符串中的每個字符,如果訪問的字符與定義的正則表達式相匹配,則將其添加到一個數(shù)組中,最后獲得該數(shù)組的項數(shù)即為字符串中漢字的個數(shù)。獲得字符串中漢字個數(shù)

更多詳細內(nèi)容:http://www.111cn.net/net/160/55657.htm


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 乌兰浩特市| 南澳县| 永仁县| 绿春县| 彭山县| 连城县| 江油市| 雅安市| 隆回县| 韶山市| 都匀市| 延长县| 贵州省| 巴里| 天峨县| 乌苏市| 扎兰屯市| 西城区| 江达县| 五莲县| 客服| 姜堰市| 英德市| 洛浦县| 西丰县| 共和县| 平乡县| 宁城县| 肇源县| 宝应县| 普兰县| 北流市| 江西省| 新安县| 长兴县| 临泽县| 伽师县| 大关县| 云梦县| 贵阳市| 井研县|