[转]正则表达式“\w”无法正常匹配中文

原文地址:正则表达式“\w”无法正常匹配中文 - YFEYI - 博客园 (cnblogs.com)

使用 webstorm 的替换功能,使用正则,发现\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

posted @   dirgo  阅读(459)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
历史上的今天:
2016-02-17 [转] 使用Spring MVC构建REST风格WEB应用
点击右上角即可分享
微信分享提示