国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - asp.net中C#獲取字符串中漢字的個數的具體實現方法

asp.net中C#獲取字符串中漢字的個數的具體實現方法

2019-12-01 11:58ASP.NET教程網 ASP.NET教程

獲取字符串中漢字原理是判斷漢字編碼然后進行判斷是漢字還是數字了,還有就是利用正則表達式,同樣是以漢字ascii為標準來獲取

符串可以包括數字,字母,漢字或者其他的字符。使用Char類型的IsDigit靜態方法可以判斷字符串中的字符是否為數字,使用Char類型中的IsLetter靜態方法可以判斷字符串中是否為字母。我們來實現一種方法來實現判斷字符串中是否為漢字,通過此方法可以計算字符串中漢字的個數:

 

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

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

 

復制代碼代碼如下:

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;

 

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

 

復制代碼代碼如下:


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

 

//定義一個函數,返回字符串中的漢字個數
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、字符串可以直接進行索引,索引得到的值的數據類型為char,所以str[i].ToString()是為了把char再度轉換為字符串。
3、使用Regex的IsMatch方法,可以判斷字符串是否與給定的正則表達式匹配,如果匹配成功則返回True,否則為False。

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

復制代碼代碼如下:


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

 

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

 

例,這個也是正常的

 

復制代碼代碼如下:

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

 

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 四虎最新紧急更新地址 | 无码一区二区三区视频 | 欧美成人a | 国产99久久精品 | 樱桃小丸子在线观看 | 国产精品不卡av | 91久久精品国产91久久 | 成人午夜精品久久久久久久网站 | 久久久久国产 | h网站在线观看 | 婷婷91| yellow在线视频免费观看 | 国产亚洲一区二区三区在线观看 | 久久精品一 | 亚洲精品福利 | 视频二区| 欧美精品在欧美一区二区少妇 | 国产日韩一区二区三免费高清 | 欧美一级黄色片 | 91精品视频在线播放 | 91视频久久| 欧美日韩一区二区三区 | 国产精品久久久久久久久久久久冷 | 精品免费av | 久久久精品电影 | 亚洲成av人影片在线观看 | 亚洲人人射 | 五月天狠狠爱 | 久久久久国产一区二区三区四区 | 一区二区三区高清 | 中文字幕av在线 | 91国自产精品中文字幕亚洲 | 国产精品久久久久久亚洲调教 | 欧美不卡| 日韩特一级 | 国产特级毛片aaaaaa毛片 | 久久99精品久久久 | 免费91视频 | 九色在线观看 | 国产成人精品久久二区二区 | 亚洲欧美日韩在线一区二区三区 |