zoukankan      html  css  js  c++  java
  • 正则表达式“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}
    
    ^[wu4E00-u9FA5uF900-uFA2D]*$
    [u4e00-u9fa5_a-zA-Z0-9_]{4,10}
    
    ^[wu4E00-u9FA5uF900-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

    总结-

    正则表达式用于字符串处理,表单验证等场合,实用高效,但用到时总是不太把握,以致往往要上网查一番。遇到多多总结吧!

  • 相关阅读:
    GC之五--SystemGC完全解读
    Java堆外内存之二:堆外内存使用总结
    Spring @Async之二:SpringBoot 自定义线程池,修改springboot的默认线程池
    JVM内存模型
    JDK源码包结构分类
    命令查看java的class字节码文件、verbose、synchronize、javac、javap
    重谈设计
    站点架构模式
    愚人节,不恶搞,我们玩真的。不服来战!
    Project Euler:Problem 86 Cuboid route
  • 原文地址:https://www.cnblogs.com/YFEYI/p/13289890.html
Copyright © 2011-2022 走看看