本文章主要讲如何使用正则匹配中文字符,中文正则表达式的匹配规则不像其余正则规则同样容易记住,下面一块儿看看这个中文正则表达式是怎么样的。html
\w匹配的仅仅是中文,数字,字母,对于国人来说,仅匹配中文时常会用到,见下前端
1 匹配中文字符的正则表达式: [\u4e00-\u9fa5]
或许你也须要匹配双字节字符,中文也是双字节的字符正则表达式
匹配双字节字符(包括汉字在内):[^\x00-\xff]
注:能够用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)post
更多经常使用正则表达式匹配规则:spa
英文字母:[a-zA-Z]
数字:[0-9]
匹配中文,英文字母和数字及_:code
^[\u4e00-\u9fa5_a-zA-Z0-9]+$
同时判断输入长度:·regexp
[\u4e00-\u9fa5_a-zA-Z0-9_]{4,10}
^[\w\u4E00-\u9FA5\uF900-\uFA2D]*$
一、一个正则表达式,只含有汉字、数字、字母、下划线不能如下划线开头和结尾:htm
^(?!_)(?!.*?_$)[a-zA-Z0-9_\u4e00-\u9fa5]+$
其中:blog
^ 与字符串开始的地方匹配开发
(?!_) 不能以_开头 (?!.*?_$) 不能以_结尾 [a-zA-Z0-9_\u4e00-\u9fa5]+ 至少一个汉字、数字、字母、下划线
$ 与字符串结束的地方匹配
放在程序里前面加@,不然须要\\进行转义 @"^(?!_)(?!.*?_$)[a-zA-Z0-9_\u4e00-\u9fa5]+$" (或者:@"^(?!_)\w*(?<!_)$" 或者 @" ^[\u4E00-\u9FA50-9a-zA-Z_]+$ " )
二、只含有汉字、数字、字母、下划线,下划线位置不限:
^[a-zA-Z0-9_\u4e00-\u9fa5]+$
三、由数字、26个英文字母或者下划线组成的字符串
^\w+$
四、2~4个汉字
@"^[\u4E00-\u9FA5]{2,4}$";
五、
//code from http://caibaojian.com/zhongwen-regexp.html ^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$
用:(Abc)+ 来分析: XYZAbcAbcAbcXYZAbcAb
来源:前端开发博客