大家好,又见面了,我是你们的朋友全栈君。 原文链接: http://caibaojian.com/zhongwen-regexp.html
这篇文章主要讲如何使用正则匹配中文字符,中文正则表达式的匹配规则不像其他正则规则一样容易记住,下面一起看看这个中文正则表达式是怎么样的。
w匹配的仅仅是中文,数字,字母,对于国人来讲,仅匹配中文时常会用到,见下
代码语言:javascript复制匹配中文字符的正则表达式: [u4e00-u9fa5]
或许你也需要匹配双字节字符,中文也是双字节的字符
代码语言:javascript复制匹配双字节字符(包括汉字在内):[^x00-xff]
注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
更多常用正则表达式匹配规则:
代码语言:javascript复制英文字母:[a-zA-Z]
数字:[0-9]
匹配中文,英文字母和数字及_:
代码语言:javascript复制//code from http://caibaojian.com/zhongwen-regexp.html
^[u4e00-u9fa5_a-zA-Z0-9] $
同时判断输入长度:·
代码语言:javascript复制[u4e00-u9fa5_a-zA-Z0-9_]{4,10}
^[wu4E00-u9FA5uF900-uFA2D]*$
1、一个正则表达式,只含有汉字、数字、字母、下划线不能以下划线开头和结尾:
代码语言:javascript复制^(?!_)(?!.*?_$)[a-zA-Z0-9_u4e00-u9fa5] $
其中:
^ 与字符串开始的地方匹配
代码语言:javascript复制(?!_) 不能以_开头
(?!.*?_$) 不能以_结尾
[a-zA-Z0-9_u4e00-u9fa5] 至少一个汉字、数字、字母、下划线
$ 与字符串结束的地方匹配
代码语言:javascript复制放在程序里前面加@,否则需要\进行转义 @"^(?!_)(?!.*?_$)[a-zA-Z0-9_u4e00-u9fa5] $"
(或者:@"^(?!_)w*(?<!_)$" 或者 @" ^[u4E00-u9FA50-9a-zA-Z_] $ " )
2、只含有汉字、数字、字母、下划线,下划线位置不限:
代码语言:javascript复制^[a-zA-Z0-9_u4e00-u9fa5] $
3、由数字、26个英文字母或者下划线组成的字符串
代码语言:javascript复制^w $
4、2~4个汉字
代码语言:javascript复制@"^[u4E00-u9FA5]{2,4}$";
5、
代码语言:javascript复制^[w-] (.[w-] )*@[w-] (.[w-] ) $
用:(Abc) 来分析: XYZAbcAbcAbcXYZAbcAb
来源: 前端开发博客
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/215478.html原文链接:https://javaforall.cn