首页 > 其他分享 >[转]正则表达式“\w”无法正常匹配中文

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

时间:2023-02-17 10:36:50浏览次数:41  
标签:u4e00 中文 匹配 u9fa5 正则表达式 zA Z0

原文地址:正则表达式“\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

标签:u4e00,中文,匹配,u9fa5,正则表达式,zA,Z0
From: https://www.cnblogs.com/dirgo/p/17129211.html

相关文章

  • 中文标题相似度检测
    前言对中文标题使用余弦相似度算法和编辑距离相似度分析进行相似度分析。准备数据集part1本次使用的数据集来源于前几年的硕士学位论文,可根据实际需要更换。结构如下所......
  • 解决C#读写txt文件中文(汉字)乱码的问题
    不少朋友遇到用System.IO.StreamReader读取包含汉字的txt文件时,经常会读出乱码(StreamWriater写文本文件也有类似的问题),原因很简单,就是文件的编码(encoding)和StreamReader/W......
  • ChatGPT中文免费小程序(AI GPGT智能助手) - ChatGPT国内小程序版在线使用
    ChatGPT中文网是一个面向中国用户的聊天机器人网站,旨在为国内用户提供一个自然的环境、有趣、实用的聊天体验。它使用最新的自然语言处理技术来帮助用户更好地理解他们的聊......
  • React 使用input限制字符长度时,部分手机(ios)输入中文时出现英文拼音
    1.在使用input的onInput方法时,控制字符长度尽量使用inputmaxLength属性进行控制不能使用以下方式handleOnInput=()=>{letfilterText=(e.target.value||'').r......
  • 数据解析-正则匹配
    一、正则基础1、为什么使用正则需求判断一个字符串是否是手机号解决编写一个函数,给函数一个字符串,如果是手机号则返回True,否则返回False代码defisPhone(phon......
  • mysql 支持中文
    1.创建表的时候添加createtableentries2(idintauto_increment,titletext,contenttext,posted_ondatetime,prim......
  • jmeter正则表达式提取器
    正则表达式提取器:允许用户从服务器的响应中通过使用perl的正则表达式提取值。该元素会作用在指定范围取样器,用正则表达式提取所需值,生成模板字符串,并将结果存储到给定的......
  • python 数据写入yaml 文件中文和排序问题
    前言数据写入yaml文件时遇到的一些问题总结,主要是中文问题和字典的排序问题。环境准备python3.8版本PyYAML版本6.0使用示例将一段python的字典类型,转成yaml文件i......
  • day10-1-中文乱码处理
    中文乱码处理1.问题抛出当表单提交的数据为中文时,会出现乱码:(1)Monster.java:packagecom.li.web.datavalid.entity;importorg.hibernate.validator.constraints.Email......
  • Python 高级编程之正则表达式(八)
    目录一、概述二、正则表达式语法1)字符匹配2)字符集合3)定位符4)分组1、定义分组2、引用分组3、命名分组三、Python的re模块1)re.match()方法2)re.search()方法3)re.match()......