常见的正则表达式

这篇具有很好参考价值的文章主要介绍了常见的正则表达式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

问题现象:

 问题分析:

解决方法:

拓展:

1、手机号或座机:

2、邮箱:

3、中文:

4、数字:

5、英文:

6、组合:


问题现象:

        今天在项目中,发现有个正则表达式匹配不上导致了数据校验不通过的问题,如下:
常见的正则表达式,正则表达式

        于是就产生了疑问:这个正则表达式有什么问题?校验手机号/座机号码的正则表达式到底该怎么写呢?


 问题分析:

        上面这个正则表达式是我用来校验用户传入的手机号和座机号

        根据这个问题就开始回想自己当初是怎么写出这个正则表达式的?关于正则表达式,不知道各位小伙伴是怎么学习的,反正我自己学的时候只会理解,从来不去记,因为这个东西我感觉用得很少,而且没有记的必要,只要在需要使用的时候,查一下资料复习一下就可以了,而更多的时候我可能只是上网搜一下校验某个字段(如手机号)的正则表达式该怎么写,所以当时就是上网搜到了这个正则表达式,然后也测过几组手机号和座机号,感觉没问题就搬过来了;现在看来是当初没有测试得全面,而且我根本没有认真去检查这个搬过来的正则表达式写得到底对不对,所以才导致了文章开头那个问题的产生,所以在这里还是要提醒一下大家:对待网上的资料一定要谨慎!!!

        入正题:通过简单的复习了一下正则表达式,然后再来观察上面那个正则表达式,就会很容易发现问题了:

        出错的正则表达式:

^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\\d{8}$|\\d{3}-\\d{8}|\\d{4}-\\{7,8}

        分析示例:

        当校验字符串为类似手机号、座机号的格式,是没有问题的:

13400009999

14500009999

15500009999

16200009999

17799990000

18899990000

19000009999

020-11800000

        错误示例:

0750-22637456

        原因很简单,其实就是因为正则表达式最后面那块错了:

\\{7,8}

        因此,只要把它改成匹配7-8为数字即可。


解决方法:

        将出错的正则表达式:

^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\\d{8}$|\\d{3}-\\d{8}|\\d{4}-\\{7,8}

        改为:

^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\\d{8}$|\\d{3}-\\d{8}|\\d{4}-\\d{7,8}

        区别在于:\\{7,8} 改为了 \\d{7,8}


拓展:

        这里记录一下我们常见的一些正则表达式(不定期更新,亲测有效,如有误欢迎纠错)

1、手机号或座机:

^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\\d{8}$|\\d{3}-\\d{8}|\\d{4}-\\d{7,8}

2、邮箱:

[\\w!#$%&'*+/=?^_`{|}~-]+(?:\\.[\\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\\w](?:[\\w-]*[\\w])?\\.)+[\\w](?:[\\w-]*[\\w])?

3、中文:

任意长度的中文字符:[\u4e00-\u9fa5]

固定长度的中文字符:^[\u4e00-\u9fa5]{指定长度}$

大于等于指定长度的中文字符:^[\u4e00-\u9fa5]{指定长度,}$

4、数字:

任意长度的数字:^[0-9]*$

固定长度的数字:^\d{指定长度}$

大于等于指定长度的数字:^\d{指定长度,}$

5、英文:

任意大小写字母:^[A-Za-z]+$

任意大写字母:^[A-Z]+$

任意小写字母:^[a-z]+$

6、组合:

任意英文、数字:^[A-Za-z0-9]+$

任意中文、数字:^[\u4e00-\u9fa50-9]+$

任意中文、英文:^[\u4e00-\u9fa5A-Za-z]+$

任意中文、英文、数字:^[\u4e00-\u9fa5A-Za-z0-9]+$文章来源地址https://www.toymoban.com/news/detail-604354.html

到了这里,关于常见的正则表达式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【SQL-正则】利用正则表达式进行过滤操作(常用正则表达式)

    1、由数字、26个英文字母或者下划线组成的字符串 2、非负整数(正整数 + 0 ) 3、正整数 4、非正整数(负整数 + 0) 5、负整数 6、整数 7、非负浮点数(正浮点数 + 0) 8、正浮点数 9、非正浮点数(负浮点数 + 0) 10、负浮点数 11、浮点数 12、由26个英文字母组成的字符串 13、

    2024年02月12日
    浏览(79)
  • Python正则表达式之学习正则表达式三步曲

            正则表达式描述了一种字符串匹配的模式,可以用来检查一个串的有无某子串,或者做子串匹配替换,取出子串等操作。也可以说正则表达式就是字符串的匹配规则,也可以理解为是一种模糊匹配,匹配满足正则条件的字符串。         1、数据验证(eg:表单验

    2024年02月15日
    浏览(60)
  • Java 之正则表达式语法及常用正则表达式汇总

    正则表达式,又称规则表达式。(英语:Regular Expression,在代码中常简写为 regex、regexp 或 RE),计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。 正则表达式是对字符串(包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称

    2024年02月09日
    浏览(68)
  • 老夫的正则表达式大成了,桀桀桀桀!!!【Python 正则表达式笔记】

    特殊字符 .^$?+*{}[]()| 为特殊字符,若想要使用字面值,必须使用 进行转义 字符类 [] [] 匹配包含在方括号中的任何字符。它也可以指定范围,例: [a-zA-Z0-9] 表示a到z,A到Z,0到9之间的任何一个字符 [u4e00-u9fa5] 匹配 Unicode 中文 [^x00-xff] 匹配双字节字符(包括中文) 在 [] 中

    2024年02月04日
    浏览(58)
  • 机器学习与数据科学-专题1 Python正则表达式-【正则表达式入门-1】

    为了完成本关任务,你需要掌握: 在 Python 中使用正则表达式; 最基础正则表达式; 正则匹配函数。 在 Python 中使用正则表达式 正可谓人生苦短,我用 Python。Python 有个特点就是库非常多,自然拥有正则匹配这种常见的库,并且此库已经嵌入在 Python 标准库中,使用起来非常

    2024年01月22日
    浏览(58)
  • 正则表达式 (用于灵活匹配文本的表达式)

    目录 . * 用于匹配任意单个字符,除了换行符。 例如使用正则表达式 a.b, 它可以匹配aab、acb、a#b 用于匹配前一个字符零次或多次。 例如,使用正则表达式 ab*c ,它可以匹配 \\\"ac\\\"、\\\"abc\\\"、\\\"abbc\\\",因为 b* 表示匹配零个或多个字符 \\\"b\\\"。所以,这个表达式可以匹配 \\\"ac\\\"(零个 \\\"b\\\"),

    2024年01月16日
    浏览(61)
  • 【编译原理】【词法分析】【正则表达式】【NFA】【DFA】【C++】正则表达式转DFA&NFA,判断字符串是否符合正则表达式的匹配算法

    显然,正则表达式、NFA、DFA的概念都很简单,所以直接上代码,注释应该解释地比较清楚, 没有万能头文件的自行替换需求库 ,如果有疑问的可以留言。 网盘链接 [自行补全]/s/1pbGT_wpB662TwFrnukXgGQ?pwd=TSIT 提取码:TSIT 原理可以参考这篇博客 传送门 本次程序由四个文件组成 文

    2024年02月11日
    浏览(84)
  • 利用正则表达式进行爬取数据以及正则表达式的一些使用方法

    Pattern:表示正则表达式 Matcher:文本匹配器,作用按照正则表达式的规则去读取字符串,从头开始读取。 在大串中去找符合匹配规则的子串。 代码示例: 需求: 把连接:https://m.sengzan.com/jiaoyu/29104.html?ivk sa=1025883i中所有的身份证号码都爬取出来。 代码示例: 需求: 把下面文

    2024年02月09日
    浏览(63)
  • 正则表达式、常用的正则

    正则表达式(Regular Expression,简称为Regex或RegExp)是用于匹配和搜索文本模式的工具。它是一个强大且灵活的字符串处理工具,可以用来检查一个字符串是否符合特定的模式,或者从一个文本中提取满足条件的部分。 在正则表达式中,可以使用不同的元字符和特殊符号来定义

    2024年02月14日
    浏览(50)
  • Python高级教程(1)——正则表达式(re.match、re.search、re.sub、compile、findall、finditer、split)、正则表达式对象、正则表达式实例

    正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配。 (1)re.match函数 re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match() 就返回 none。 函数语法: 通过re.match匹配成功,可以使⽤group⽅法来提取数据

    2024年02月04日
    浏览(64)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包