正則表達式“\w”無法正常匹配中文


問題描述-

使用RegExp驗證表單中的“真實姓名”一欄時,出現‘/w’無法滿足需求,固上網尋求解決方案。

問題解決-

采用來自http://caibaojian.com/zhongwen-regexp.html的解決方案

匹配2~4個中文字符

"^[\u4E00-\u9FA5]{2,4}$"

問題基本解決。

 

同時鏈接中有很多的拓展知識

\w匹配的僅僅是中文,數字,字母,對於國人來講,僅匹配中文時常會用到,見下:

匹配中文字符的正則表達式: [\u4e00-\u9fa5]

或許你也需要匹配雙字節字符,中文也是雙字節的字符

匹配雙字節字符(包括漢字在內):[^\x00-\xff]

注:可以用來計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)

更多常用正則表達式匹配規則:

英文字母:[a-zA-Z]

數字:[0-9]

匹配中文,英文字母和數字及_:

^[\u4e00-\u9fa5_a-zA-Z0-9]+$

同時判斷輸入長度:·

[\u4e00-\u9fa5_a-zA-Z0-9_]{4,10}

^[\w\u4E00-\u9FA5\uF900-\uFA2D]*$

 

[\u4e00-\u9fa5_a-zA-Z0-9_]{4,10}

^[\w\u4E00-\u9FA5\uF900-\uFA2D]*$

 

 

1、一個正則表達式,只含有漢字、數字、字母、下划線不能以下划線開頭和結尾:

^(?!_)(?!.*?_$)[a-zA-Z0-9_\u4e00-\u9fa5]+$

其中:

^ 與字符串開始的地方匹配

(?!_)  不能以_開頭 (?!.*?_$)  不能以_結尾 [a-zA-Z0-9_\u4e00-\u9fa5]+  至少一個漢字、數字、字母、下划線

$  與字符串結束的地方匹配

放在程序里前面加@,否則需要\\進行轉義 @"^(?!_)(?!.*?_$)[a-zA-Z0-9_\u4e00-\u9fa5]+$" (或者:@"^(?!_)\w*(?<!_)$" 或者 @" ^[\u4E00-\u9FA50-9a-zA-Z_]+$ " )

2、只含有漢字、數字、字母、下划線,下划線位置不限:

^[a-zA-Z0-9_\u4e00-\u9fa5]+$

 

3、由數字、26個英文字母或者下划線組成的字符串

^\w+$

 

4、2~4個漢字

@"^[\u4E00-\u9FA5]{2,4}$";

 

5、

^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$

用:(Abc)+ 來分析: XYZAbcAbcAbcXYZAbcAb

 

總結-

正則表達式用於字符串處理,表單驗證等場合,實用高效,但用到時總是不太把握,以致往往要上網查一番。遇到多多總結吧!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM