[转]正则表达式“\w”无法正常匹配中文
2023-09-11 14:16:15 时间
原文地址:正则表达式“\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
相关文章
- [Hadoop]Hive r0.9.0中文文档(二)之联表查询Join
- [C++]VisualAssistX中文注释提示错误 解决办法
- 为Elasticsearch添加中文分词,对比分词器效果
- lua正则表达式如何匹配中文
- wazuh官方安装指南(中文译版本)
- Android中文API(99)—— RelativeLayout
- Linux服务器评测脚本 中文IO脚本简单易懂
- E-MapReduce解决hive comment中文乱码问题
- 解决 QT 界面中文显示乱码问题
- Python 将中文、字母转成数字
- pycharm 中文乱码
- Hadoop-2.2.0中文文档—— Common - CLI MiniCluster
- vim、gvim 在 windows 下中文乱码的终极解决方案
- django-redis 中文文档
- Servlet Filter实现全站统一编码,解决中文乱码问题
- 学习经验分享之七:YOLOv5代码中文注释
- 解决Python中文注释报错