中文正则表达式匹配

\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]*$

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


作者:每一天为明天168

链接:https://www.jianshu.com/p/8695c2ba8ace

来源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

声明:本站所有文章,如无特殊说明或,均为原创发布。商业转载请联系作者获得授权,非商业转载请注明出处。本站所有图片如无特殊说明均为AI生成。
真诚赞赏,手留余香
赞赏
算法
进制计数法
2021-12-23
CSS
iconfont 字体生成原理
2021-12-24
Jone
在什么样的花园里面,挖呀挖呀挖
种什么样的种子,开什么样的花
随机推荐
视频剪辑软件 Shotcut 笔记
FFmpeg 修改默认音轨
JavaScript 检查 Date 是否为 Invalid Date
MySQL的外键总结
TypeScript 和 Koa 实践
MySQL 的 sql_mode 模式介绍:为什么 MySQL 中 int,float,double 类型字段插入空字符时自动转为0
如何使用命令修改 MySQL 数据库名称
Linux 下 configure、make 、make test/make check、sudo make install 的作用
MySQL 表名预处理
JavaScript 和 CSS 检测横屏适配

微信联系我

夜间模式切换
回到顶部