25个常用的正则表达式汇总

article/2025/8/26 8:08:13

319ec90dd95abcde9454a570b462eaab.png

来源 | http://www.fly63.com/

正则表达式非常有用。正则表达式可用于每种语言。就像 json 一样,它们是通用的。在日常开发中,了解一些常用的正则表达式可以大大提高你的工作效率。

今天,我给大家分享25个常用的正则表达式,希望大家能提高代码效率!

1、手机号码的校验

 
const phoneReg = /^[1][3,4,5,6,7,8,9][0-9]{9}$/const phoneStr1 = '18886233487'
console.log(phoneReg.test(phoneStr1)) // trueconst phoneStr2 = '17283017203897'
console.log(phoneReg.test(phoneStr2)) // false

2、身份证的校验

 
const sfzReg = /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/const sfzStr1 = '415106199801012130'
console.log(sfzReg.test(sfzStr1)) // trueconst sfzStr2 = '718381298381212183'
console.log(sfzReg.test(sfzStr2)) // false

3、邮箱的校验

 
const emailReg = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/const emailStrWY = '956666@163.com' // 163邮箱
const emailStrQQ = '956666@qq.com' // qq邮箱
console.log(emailReg.test(emailStrWY)) // true
console.log(emailReg.test(emailStrQQ)) // trueconst noEmail = '72873213.com'
console.log(emailReg.test(noEmail)) // false

4、URL的校验

 
const urlReg = /^((https?|ftp|file):\/\/)?([\da-z\.-]+)\.([a-z\.]{2,6})([\/\w \.-]*)*\/?$/const urlStr1 = 'https://haha.sunshine.com/xxx/xxx'
console.log(urlReg.test(urlStr1)) // trueconst urlStr2 = 'sss://haha.sunshine.com/xxx/xxx'
console.log(urlReg.test(urlStr2)) // false

5、IPv4的校验

 
const ipv4Reg = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/const ipv4Str1 = '122.12.56.65'
console.log(ipv4Reg.test(ipv4Str1)) // trueconst ipv4Str2 = '122.12.56.655'
console.log(ipv4Reg.test(ipv4Str2)) // false

6、16进制颜色的校验

 
const color16Reg = /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/const color16Str1 = '#fff'
console.log(color16Reg.test(color16Str1)) // trueconst color16Str2 = '#1234567'
console.log(color16Reg.test(color16Str2)) // false

7、日期 YYYY-MM-DD

 
const dateReg = /^\d{4}(\-)\d{1,2}\1\d{1,2}$/const dateStr1 = '2021-10-10'
console.log(dateReg.test(dateStr1)) // trueconst dateStr2 = '2021-01-01 1'
console.log(dateReg.test(dateStr2)) // false

8、日期 YYYY-MM-DD hh:mm:ss

 
const dateReg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/const dateStr1 = '2021-10-10 16:16:16'
console.log(dateReg.test(dateStr1)) // trueconst dateStr2 = '2021-10-10 16:'
console.log(dateReg.test(dateStr2)) // false

9、整数的校验

 
const intReg = /^[-+]?\d*$/const intNum1 = 12345
console.log(intReg.test(intNum1)) // trueconst intNum2 = 12345.1
console.log(intReg.test(intNum2)) // false

10、小数的校验

 
const floatReg = /^[-\+]?\d+(\.\d+)?$/const floatNum = 1234.5
console.log(floatReg.test(floatNum)) // true

11、保留n位小数

 
function checkFloat(n) {return new RegExp(`^([1-9]+[\d]*(.[0-9]{1,${n}})?)$`)
}
// 保留2位小数
const floatReg = checkFloat(2)const floatNum1 = 1234.5
console.log(floatReg.test(floatNum1)) // trueconst floatNum2 = 1234.55
console.log(floatReg.test(floatNum2)) // trueconst floatNum3 = 1234.555
console.log(floatReg.test(floatNum3)) // false

12、邮政编号的校验

 
const postalNoReg = /^\d{6}$/const postalNoStr1 = '522000'
console.log(postalNoReg.test(postalNoStr1)) // trueconst postalNoStr2 = '5220000'
console.log(postalNoReg.test(postalNoStr2)) // false

13、QQ号的校验

说明:5-11位数字

 
const qqReg = /^[1-9][0-9]{4,10}$/const qqStr1 = '1915801633'
console.log(qqReg.test(qqStr1)) // trueconst qqStr2 = '191580163333'
console.log(qqReg.test(qqStr2)) // false

14、微信号的校验

说明:6至20位,以字母开头,字母,数字,减号,下划线

 
const wxReg = /^[a-zA-Z]([-_a-zA-Z0-9]{5,19})+$/const wxStr1 = 'linsanxin885577'
console.log(wxReg.test(wxStr1)) // trueconst wxStr2 = '厉害了我的vx'
console.log(wxReg.test(wxStr2)) // false

15、车牌号的校验

 
const carNoReg = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}[A-Z0-9]{4}[A-Z0-9挂学警港澳]{1}$/const carNoStr1 = '粤A12345'
console.log(carNoReg.test(carNoStr1)) // trueconst carNoStr2 = '广东A12345'
console.log(carNoReg.test(carNoStr2)) // false

16、只含字母的字符串

 
const letterReg = /^[a-zA-Z]+$/const letterStr1 = 'sunshineLin'
console.log(letterReg.test(letterStr1)) // trueconst letterStr2 = 'sunshine_Lin'
console.log(letterReg.test(letterStr2)) // false

17、包含中文的字符串

 
const cnReg = /[\u4E00-\u9FA5]/const cnStr1 = '我是sunshine_Lin,林三心'
console.log(cnReg.test(cnStr1)) // trueconst cnStr2 = 'sunshine_Lin'
console.log(cnReg.test(cnStr2)) // false

18、密码强度的校验

说明:密码中必须包含字母、数字、特称字符,至少8个字符,最多30个字符

 
const passwordReg = /(?=.*[0-9])(?=.*[a-zA-Z])(?=.*[^a-zA-Z0-9]).{8,30}/const password1 = 'sunshine_Lin12345..'
console.log(passwordReg.test(password1)) // trueconst password2 = 'sunshineLin12345'
console.log(passwordReg.test(password2)) // false

19、字符串长度n的校验

 
function checkStrLength(n) {return new RegExp(`^.{${n}}$`)
}// 校验长度为3的字符串
const lengthReg = checkStrLength(3)const str1 = 'hhh'
console.log(lengthReg.test(str1)) // trueconst str2 = 'hhhhh'
console.log(lengthReg.test(str2)) // false

20、文件拓展名的校验

 
function checkFileName (arr) {arr = arr.map(name => `.${name}`).join('|')return new RegExp(`(${arr})$`)
}const filenameReg = checkFileName(['jpg', 'png', 'txt'])const filename1 = 'sunshine.jpg'
console.log(filenameReg.test(filename1)) // true
const filename2 = 'sunshine.png'
console.log(filenameReg.test(filename2)) // true
const filename3 = 'sunshine.txt'
console.log(filenameReg.test(filename3)) // true
const filename4 = 'sunshine.md'
console.log(filenameReg.test(filename4)) // false

21、匹配img和src

 
const imgReg = /<img.*?src=[\"|\']?(.*?)[\"|\']?\s.*?>/igconst htmlStr = '<div></div><img src="sunshine.png" /><img src="sunshine111.png" />'console.log(imgReg.exec(htmlStr))
// [
//   '<img src="sunshine.png" />',
//   'sunshine.png',
//   index: 11,
//   input: '<div></div><img src="sunshine.png" /><img src="sunshine111.png" />',
//   groups: undefined
// ]
console.log(imgReg.exec(htmlStr))
// [
//   '<img src="sunshine111.png" />',
//   'sunshine111.png',
//   index: 37,
//   input: '<div></div><img src="sunshine.png" /><img src="sunshine111.png" />',
//   groups: undefined
// ]

22、匹配html中的注释

 
const noteReg = /<!--(.*?)-->/gconst htmlStr = '<!--一个div标签--> <div></div> <!--一个div标签--> <div></div>'console.log(noteReg.exec(htmlStr))
// [
//   '<!--一个div标签-->',
//   '一个div标签',
//   index: 0,
//   input: '<!--一个div标签--> <div></div> <!--一个div标签--> <div></div>',
//   groups: undefined
// ]
console.log(noteReg.exec(htmlStr))
// [
//   '<!--一个div标签-->',
//   '一个div标签',
//   index: 27,
//   input: '<!--一个div标签--> <div></div> <!--一个div标签--> <div></div>',
//   groups: undefined
// ]

23、匹配html中的style

 
const styleReg = /([(\s+\w+=)|>])/gconst htmlStr = '<div><span></span></div>'console.log(styleReg.exec(htmlStr))
// [
//   '>',
//   '>',
//   index: 5,
//   input: '<div><span></span></div>',
//   groups: undefined
// ]
console.log(styleReg.exec(htmlStr))
// [
//   '>',
//   '>',
//   index: 36,
//   input: '<div><span></span></div>',
//   groups: undefined
// ]

24、匹配html中的颜色

 
const colorReg = /#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})/gconst htmlStr = '<div><span></span></div>'console.log(colorReg.exec(htmlStr))
// [
//   '#000',
//   '000',
//   index: 23,
//   input: '<div><span></span></div>',
//   groups: undefined
// ]
console.log(colorReg.exec(htmlStr))
// [
//   '#fff',
//   'fff',
//   index: 49,
//   input: '<div><span></span></div>',
//   groups: undefined
// ]

25、匹配htmlTag(html标签)

 
const endReg = /<("[^"]*"|'[^']*'|[^'">])*>/gconst htmlStr = '<div><span></span></div><h1></h1>'console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))

学习更多技能

请点击下方公众号

80b476317ce71cc6055d954c16f868ec.gif

1ee6f5b49047647c04856b87c1b16379.png

e5b819bae8b541f33febc21c12c1b209.png


http://chatgpt.dhexx.cn/article/6ulcJhGR.shtml

相关文章

正则表达式基本语法

一、核心作用&#xff1a; –文本的复杂处理 二、正则表达式的定义&#xff1a; 描述一个规则&#xff0c;通过这个规则可以匹配一类字符串 三、正则表达式的优势和用途&#xff1a; 优势&#xff1a;强大而灵活的文本处理工具 用途&#xff1a;大部分编程语言、数据库、文…

正则表达式的语法规则

一、行定位符&#xff08;^和$&#xff09; 行定位符就是用来描述字串的边界。“^”表示行的开始&#xff1b;“$”表示行的结尾。如&#xff1a; ^tm : 该表达式表示要匹配字串tm的开始位置是行头&#xff0c;如tm equal Tomorrow Moon就可以匹配 tm$ : 该表达式表示要匹配字串…

正则表达式常用语法解析

正则表达式常用语法解析 什么是正则表达式正则表达式之元字符匹配位置的元字符 ^、$、/b匹配字符的元字符 .、\w、\W、\s、\S、\d、\D 正则表达式之文字匹配字符类字符转义反义 正则表达式之限定符正则表达式之字符的运算替换分组反向引用零宽度断言负向零宽度断言优先级顺序 什…

Python正则表达式大全

定义&#xff1a;正则表达式是对字符串&#xff08;包括普通字符&#xff08;例如&#xff0c;a 到 z 之间的字母&#xff09;和特殊字符&#xff08;称为“元字符”&#xff09;&#xff09;操作的一种逻辑公式&#xff0c;就是用事先定义好的一些特定字符、及这些特定字符的组…

JS正则表达式语法大全(非常详细)

前面几节讲解了如何在 JavaScript 中使用正则表达式&#xff0c;以及如何执行匹配&#xff0c;本节就来讲一下正则表达式的具体语法。 正则表达式是一种通用的工具&#xff0c;在 JavaScript、PHP、Java、Python、C 等几乎所有的编程语言中都能使用&#xff1b;但是&#xff0c…

正则表达式语法及例子

正则表达式的语法规则 一、行定位符&#xff08;^和$&#xff09; 行定位符就是用来描述字串的边界。“^”表示行的开始&#xff1b;“$”表示行的结尾。如&#xff1a; ^tm : 该表达式表示要匹配字串tm的开始位置是行头&#xff0c;如tm equal Tomorrow Moon就可以匹配 tm$ :…

最全的常用正则表达式大全

一、校验数字的表达式 1 数字&#xff1a;^[0-9]*$ 2 n位的数字&#xff1a;^\d{n}$ 3 至少n位的数字&#xff1a;^\d{n,}$ 4 m-n位的数字&#xff1a;^\d{m,n}$ 5 零和非零开头的数字&#xff1a;^(0|[1-9][0-9]*)$ 6 非零开头的最多带两位小数的数字&#xff1a;^([1-9][…

正则表达式的语法

正则表达式语法简介  正则表达式是独立于任何语言的&#xff0c;虽然不同的 语言中其语法略有不同。  正则表达式的语法可以分为 • 特殊字符 • 边界匹配符 • 逻辑操作符 • 量词等  这些基本的语法规则合成使用&#xff0c;共同构成了正 则表达式强大的表示和匹配功能…

正则表达式基础语法大全

正则表达式基础语法 1.普通字符&#xff1a; 字母、数字、汉子、下划线、以及没有特殊定义的标点符号&#xff0c;都是“普通字符”。表达式中的普通字符&#xff0c;在匹配一个字符串的时候&#xff0c;匹配与之相同的一个字符。 2.简单的转义字符&#xff1a; 3.标准字符集…

最全常用正则表达式大全

一、校验数字的表达式 1. 数字&#xff1a;^[0-9]*$ 2. n位的数字&#xff1a;^\d{n}$ 3. 至少n位的数字&#xff1a;^\d{n,}$ 4. m-n位的数字&#xff1a;^\d{m,n}$ 5. 零和非零开头的数字&#xff1a;^(0|[1-9][0-9]*)$ 6. 非零开头的最多带两位小数的数字&#xff1a;^…

正则表达式的语法汇总

文章目录 1.正则表达式的基本语法1.1两个特殊符号 ^ 和 $^ 正则表达式的起始符$ 正则表达式的结束符^$ 结合使用不使用 ^$ 1.2 出现次数的表示符号 * &#xff1f;* 表示出现 0次 或者 至少1次 表示出现 至少1次? 表示出现 0次 或者 1次 1.3 指定出现次数的范围 {}使用{m,n} …

Java 集合List转 Map 和Map转List的方法总结(举例说明!)

最近遇到了一个场景是&#xff0c;要将从数据库中查出的List<bean>转换为List<map>然后再取map中的value&#xff0c;最后把所有的value写到Excel中。由于这个bean的属性太多了&#xff0c;我最开始没有采用list转map的方式取获取value&#xff0c;而是在for循环中…

Java8:list转Map

小故事 最近项目中&#xff0c;因为业务需要&#xff0c;我使用了for循环进行List转Map&#xff0c;项目经理看到了&#xff0c;深深的”鄙视“了我&#xff0c;说你怎么写这么古老的写法&#xff0c;一点不优雅。于是我就想到了Java8的新特性&#xff0c;使用stream流进行操作…

Java8 Stream(11)List转Map

一、前言 对于聚合统计可以参考下面博客。 Java8 Stream&#xff08;12&#xff09;Collectors 分组统计 详解 开发中&#xff0c;List转Map是非常常见的操作&#xff0c;例如&#xff1a; List<T> 转 Map<String, T>List<T> 转 Map<String, List<T&…

APP移动测试用例总结,总有你要用到的

目录 前言 一、首先是测试资源确认及准备 二、测试用例的设计与评审 三、UI测试 四、功能测试 五、中断测试 六、兼容性及适配测试 七、性能测试 八、稳定性测试 九、测试分析及测试报告输出 十、移动端测试用例的实践经验 总结 重点&#xff1a;配套学习资料和…

设计水杯,门锁的测试用例

测试用例公式&#xff1a; 功能测试 界面测试 性能测试 兼容性测试 易用性测试 安全测试 一般用脑图或者Excel来编写测试用例 百度脑图 - 便捷的思维工具 水杯的测试用例&#xff1a; 门锁的测试用例&#xff1a; 测试用例越多越好吗&…

APP 测试用例(大部分 APP 通用)

APP 测试用例 根据 场景设计法 来设计测试用例 安装与卸载权限设置软件更新登录与注册网络环境运行日历控件异常测试兼容性测试

在线音乐播放器测试用例

登录功能测试用例 当用户输入正确的用户名和密码时,方可登录成功,否则,会给出相应得提示。 上传音乐测试用例 用户选择上传的音乐后缀是.mp3时,才能上传成功。 查询音乐测试用例 查询音乐支持指定名称查询和模糊匹配查询。 安全测试 安全测试作为系统测试的主要部分&#xff0c…