当前位置: 首页 > news >正文

一篇文章搞定js正则表达式

我们测试正则表达式是否正确的方法有很多,例如通过正则表达式找到拼配的字符串:

在vscode编辑器中点击搜索框中的第三个按钮就可以实现:

 

 或者 在浏览器中的控制台也可以实现:

 

 我们可以通过下面的在线网站来测试你写的正则是否正确----推荐使用

https://regex101.com/

下面是网站截图,使用方法:

 下面来正式学习正则表达式:

一、限定符

1、限定符--问号 ?

used?

这个问号代表它前面这个字符d需要出现0次或者1次,也就是d这个字符可有可无

可以看到used? 可以匹配到 use或者used

 2、限定符--星号 *

ab*c

他会去匹配0个或多个字符,代表着b可以没有也可以出现多次

 3、限定符--加号 +

ab+c

他会匹配出现1次以上的字符,也就是匹配b出现1次或1次以上的字符

 4、限定符精确匹配--{}

ab{6}c

我们要指定这里b出现的次数为6次,就在花括号里面写上6,

ab{2,6}c

当然花括号也允许我们输入一个范围。比如我们希望字符出现的次数为2到6之间,此时代表得是包含2和6的

ab{2,6}c

 ab{2,}c

还有这种写法,代表匹配的是b的次数为2次以上的。

 注意:我们上面讲的都是匹配的单个字符,想匹配多个字符怎么办?

答:将多个字符用括号括起来再加上限定符去匹配。

 二、“或” 运算

a (cat | dog)

注意:括号必不可少

三、字符类

[abc]+

这里方括号里面的内容代表要求你匹配的字符只能取自于他们,所以只要包含他们其中的一个就会匹配上

 另外,我们可以在中括号中指定字符的范围

[a-z]

代表所有的小写英文字符

 [a-zA-Z0-9]+

匹配的是小写a-z以及大写A-Z以及数字的字符

 脱字符尖号 ^ 

如果我们在方括号前面写一个尖号脱字符,则代表要求匹配除了尖号后面列出的(以外)的字符

[^0-9] 

代表所有的非数字字符,包括换行符

 四、元字符

正则表达式中的大多数元字符都以反斜杠开头

\d  

数字字符,等同于[0-9]

\w 

代表单词字符(英文、数字及下划线)

\s 

空白符(包含Tab和换行符)

\D

与小写d相反,代表非数字字符

\W 

代表非单词字符

 \S

代表非空白字符

\b 

代表单词的开头或结尾,也就是单词的分界处

 句点 . 

代表任意字符,但不包含换行符

 特殊字符 尖号^ 

会匹配行首的ad

 特殊字符 美元符$

会匹配行尾的ad

 五、贪婪与懒惰匹配

例如我们想要匹配span的前后标签

有人说,这么写

 此时我们可以看到,这样匹配会把整个span标签匹配起来

原因是因为句点符号会匹配尽可能多的字符,所以我们加上问号,问号代表出现0次或者1次,

这样就匹配成功了。

 接下来,来看一下简单的实例:

1、颜色值匹配

匹配出所有颜色中十六进制的RGB颜色值

/#[a-fA-F0-9]{6}\b/

解析:因为十六进制都是a-f之间的值,包含大小写,并且是6位,接着我们用\b来表示单词的结尾

 2、IP地址匹配

\d+会匹配任何长度大于1的数字

\.代表句点这个符号,因为句点在正则中是特殊的字符,因此需要反斜杠转义

 此时我们看到还匹配出一个错误的ip,因为ip都是0-255的数字

所以上面的方案不可行,看如下方案,我们按位匹配

25[0-5] 第一种开头是25,第三位肯定是0-5之间

2[0-4]\d+ 第二种开头是2,第二位是0-4,那第三位可以取0-9之间任意的数用\d代替

[01]\d\d 第三种开头是0或者1,那第二位和第三位可以取0-9的任意数,都用\d代替

我们知道ip地址每一部分都可以是两位或者一位,所以我们在第三种情况开头和结尾都加上问号即可:[01]?\d\d?

数字部分已经匹配好了,接下来匹配句点

(25[0-5]|2[0-4]\d|[01]?\d\d?)\.)

因为句点是只有三个,所以我们对于加上句点的正则用{3}只限制前三部分,最后一部分复制前面的即可

\b((25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(25[0-5]|2[0-4]\d|[01]?\d\d?)\b

 

 这样就筛选好啦,成功的将256.1.1.0这个不符合要求的ip过滤掉。

总结:

 你学会啦吗~

相关文章:

一篇文章搞定js正则表达式

我们测试正则表达式是否正确的方法有很多,例如通过正则表达式找到拼配的字符串: 在vscode编辑器中点击搜索框中的第三个按钮就可以实现: 或者 在浏览器中的控制台也可以实现: 我们可以通过下面的在线网站来测试你写的正则是否正确…...

[数据结构] 用两个队列实现栈详解

文章目录 一、队列实现栈的特点分析 1、1 具体分析 1、2 整体概括 二、队列模拟实现栈代码的实现 2、1 手撕 队列 代码 queue.h queue.c 2、2 用队列模拟实现栈代码 三、总结 🙋‍♂️ 作者:Ggggggtm 🙋‍♂️ 👀 专栏&#xff1…...

官宣|Apache Flink 1.17 发布公告

Apache Flink PMC(项目管理委员)很高兴地宣布发布 Apache Flink 1.17.0。Apache Flink 是领先的流处理标准,流批统一的数据处理概念在越来越多的公司中得到认可。得益于我们出色的社区和优秀的贡献者,Apache Flink 在 Apache 社区…...

动态内存管理+动态通讯录【C进阶】

文章目录为什么存在动态内存分配❓👉动态内存函数👈malloc&freecallocrealloc❌常见的动态内存错误❌练习题🫠C/C程序的内存开辟🤔柔性数组柔性数组的特点柔性数组的优势:star:动态通讯录:star:初始化添加销毁为什么存在动态内…...

基于pytorch+Resnet101加GPT搭建AI玩王者荣耀

本源码模型主要用了SamLynnEvans Transformer 的源码的解码部分。以及pytorch自带的预训练模型"resnet101-5d3b4d8f.pth"本资源整理自网络,源地址:https://github.com/FengQuanLi/ResnetGPT注意运行本代码需要注意以下几点 注意!&a…...

多线程控制讲解与代码实现

多线程控制 回顾一下线程的概念 线程是CPU调度的基本单位,进程是承担分配系统资源的基本单位。linux在设计上并没有给线程专门设计数据结构,而是直接复用PCB的数据结构。每个新线程(task_struct{}中有个指针都指向虚拟内存mm_struct结构&am…...

清晰概括:进程与线程间的区别的联系

相关阅读: 🔗通俗简介:操作系统之进程的管理与调度🔗如何使用 jconsole 查看Java进程中线程的详细信息? 目录 一、进程与线程 1、进程 2、线程 二、进程与线程之间的区别和联系 1、区别 2、联系 一、进程与线程 …...

自定义类型 (结构体)

文章目录📬结构体的声明🔎1.结构的基础知识🔎2.结构的声明🔎3.特殊的声明🔎4.结构的自引用🔎5.结构体变量的定义和初始化🔎6.结构体内存对齐🔎7.修改默认对齐数🔎8.结构体…...

第14届蓝桥杯STEMA测评真题剖析-2023年3月12日Scratch编程初中级组

[导读]:超平老师的《Scratch蓝桥杯真题解析100讲》已经全部完成,后续会不定期解读蓝桥杯真题,这是Scratch蓝桥杯真题解析第113讲。 蓝桥杯选拔赛现已更名为STEMA,即STEM 能力测试,是蓝桥杯大赛组委会与美国普林斯顿多…...

程序员接私活一定要知道的事情,我走的弯路你们都别走了

文章目录前言一、程序员私活的种类1.兼职职位众包2.自由职业者驻场3.项目整包二、这3种私活可以接1.有熟人2.七分熟的项目3.需求明确的项目三、这3种私活不要接1.主动找上门的中介单2.一味强调项目简单好做3.外行人给你拉的项目四、接单的渠道1.线下渠道2.线上渠道3.比较靠谱的…...

十二届蓝桥杯省赛c++(下)

1、 拿到题目一定要读懂题意&#xff0c;不要看到这题目就上来模拟什么闰年&#xff0c;一月的天数啥的。这个题目问你当天的时间&#xff0c;就说明年月日跟你都没关系&#xff0c;直接无视就好了。 #include <iostream> #include <cstring> #include <algori…...

数据结构与算法——堆的基本存储

目录 一、概念及其介绍 二、适用说明 三、结构图示 四、Java 实例代码 五.堆和栈的区别 一、概念及其介绍 堆(Heap)是计算机科学中一类特殊的数据结构的统称。 堆通常是一个可以被看做一棵完全二叉树的数组对象。 堆满足下列性质&#xff1a; 堆中某个节点的值总是不大…...

来了来了 !!!K8s指令、yaml部署

文章目录k8s资源清单一、k8s资源指令1、基础操作2、命令手册二、资源清单1、required2、optional3、other4、资源清单格式5、常用命令三、部署实例1、nginx3、eureka部署k8s资源清单 一、k8s资源指令 1、基础操作 #创建且运行一个pod #deployment、rs、pod被自动创建 kubect…...

spring-cloud-feign实战笔记

feign 配置 针对单个feign接口进行配置feign:client:config:# feignName 注意这里与contextId一致&#xff0c;不能写成name&#xff08;FeignClientFactoryBean#configureFeign&#xff09;# 不能写成 client-b (微服务名称)&#xff0c;否则不生效helloFeignClient: # conte…...

【Pytorch】利用PyTorch实现图像识别

本文参加新星计划人工智能(Pytorch)赛道&#xff1a;https://bbs.csdn.net/topics/613989052 这是目录使用torchvision库的datasets类加载常用的数据集或自定义数据集使用torchvision库进行数据增强和变换&#xff0c;自定义自己的图像分类数据集并使用torchvision库加载它们使…...

在家查找下载最新《柳叶刀》The Lancet期刊文献的方法

《柳叶刀》The Lancet简介&#xff1a; 《柳叶刀》The Lancet是全球顶尖综合性医学期刊&#xff0c;每周都会发表来自世界各地顶尖科学家的研究精粹。是由托马斯威克利&#xff08;Thomas Wakley&#xff09;创办于1823年&#xff0c;由爱思唯尔&#xff08;Elsevier&#xff…...

当下的网络安全行业前景到底怎么样?还能否入行?

前言网络安全现在是朝阳行业&#xff0c;缺口是很大。不过网络安全行业就是需要技术很多的人达不到企业要求才导致人才缺口大常听到很多人不知道学习网络安全能做什么&#xff0c;发展前景好吗&#xff1f;今天我就在这里给大家介绍一下。网络安全作为目前比较火的朝阳行业&…...

SpringCloud:SpringAMQP介绍

Spring AMQP是基于RabbitMQ封装的一套模板&#xff0c;并且还利用SpringBoot对其实现了自动装配&#xff0c;使用起来非常方便。Spring AMQP官方地址 Spring AMQP提供了三个功能&#xff1a; 自动声明队列、交换机及其绑定关系基于注解的监听器模式&#xff0c;异步接收消息封…...

第十三届蓝桥杯省赛 python B组复盘

文章目录前言主要内容&#x1f99e;试题 A&#xff1a;排列字母思路代码&#x1f99e;试题 B&#xff1a;寻找整数思路代码&#x1f99e;试题 C&#xff1a;纸张尺寸思路代码&#x1f99e;试题 D&#xff1a;数位排序思路代码&#x1f99e;试题 E&#xff1a;蜂巢思路代码&…...

SQL注入之HTTP请求头注入

Ps&#xff1a; 先做实验&#xff0c;在有操作的基础上理解原理会更清晰更深入。 一、实验 sqli-lab 1. User-Agent注入 特点&#xff1a;登陆后返回用户的 User-Agent --> 服务器端可能记录用户User-Agent 输入不合法数据报错 payload: and updatexml(1,concat("~&…...

Metasploit详细教程

第一步&#xff1a;安装和启动Metasploit 您可以从Metasploit官方网站下载适用于您操作系统的Metasploit框架。安装Metasploit框架后&#xff0c;您可以使用以下命令来启动Metasploit&#xff1a; msfconsole该命令将启动Metasploit控制台。 第二步&#xff1a;查找目标设备…...

【ChatGPT】Notion AI 从注册到体验:如何免费使用

欢迎关注【youcans的GPT学习笔记】原创作品&#xff0c;火热更新中 【ChatGPT】Notion AI 从注册到体验1. Notion AI 介绍1.1 Notion AI 简介1.2 Notion AI 的核心能力1.3 Notion AI 与 ChatGPT 的比较2. Notion AI 国内用户注册2.1 PC 端用户注册2.2 移动端用户注册3. Notion …...

每个开发人员都需要掌握的10 个基本 SQL 命令

SQL 是一种非常常见但功能强大的工具&#xff0c;它可以帮助从任何数据库中提取、转换和加载数据。数据查询的本质在于SQL。随着公司和组织发现自己处理的数据量迅速增加&#xff0c;开发人员越来越需要有效地使用数据库来处理这些数据。所以想要暗恋数据领域&#xff0c;SQL是…...

Vue项目预渲染

前言 Ajax 技术的出现&#xff0c;让我们的 Web 应用能够在不刷新的状态下显示不同页面的内容&#xff0c;这就是单页应用。在一个单页应用中&#xff0c;往往只有一个 html 文件&#xff0c;然后根据访问的 url 来匹配对应的路由脚本&#xff0c;动态地渲染页面内容。单页应用…...

可别再用BeanUtils了(性能拉胯),试试这款转换神器

老铁们是不是经常为写一些实体转换的原始代码感到头疼&#xff0c;尤其是实体字段特别多的时候。有的人会说&#xff0c;我直接使用get/set方法。没错&#xff0c;get/set方法的确可以解决&#xff0c;而且也是性能较高的处理方法&#xff0c;但是大家有没有想过&#xff0c;要…...

Transformer 杂记

Transformer输入的是token,来自语言序列的启发。卷积神经网络&#xff08;CNN&#xff09;是如何进行物种分类的.它实际是直接对特征进行识别&#xff0c;也就是卷积神经网络最基本的作用&#xff1a;提取图像的特征。例如&#xff1a;卷积神经网络判断一只狗的时候&#xff0c…...

实现异步的8种方式

前言异步执行对于开发者来说并不陌生&#xff0c;在实际的开发过程中&#xff0c;很多场景多会使用到异步&#xff0c;相比同步执行&#xff0c;异步可以大大缩短请求链路耗时时间&#xff0c;比如&#xff1a;「发送短信、邮件、异步更新等」&#xff0c;这些都是典型的可以通…...

Github隐藏功能显示自己的README,个人化你的Github主页

Github隐藏功能&#xff1a;显示自己的README 你可能还不知道&#xff0c;GitHub 悄悄上线了一个全新的个人页功能&#xff0c;显示一个自定义的 README.MD 在个人首页。要激活此功能&#xff0c;需要新建一个与自己 ID 同名的 Repository&#xff0c;新 Repo 里的README.MD将…...

单片机 | 51单片机原理

【金善愚】 单片机应用原理篇 笔记整理 课程视频 &#xff1a;https://space.bilibili.com/483942191/channel/collectiondetail?sid51090 文章目录一、引脚分布介绍1.分类2.电源引脚3.时钟引脚(2根)4.控制引脚(4根)5.端口引脚(32根)二、存储器结构及空间分布介绍1.存储器的划…...

(只需五步)注册谷歌账号详细步骤,解决“此电话号码无法验证”问题

目录 第一步&#xff1a;打开google浏览器 第二步&#xff1a;设置语言为英语&#xff08;美国&#xff09; 第三步&#xff1a;点击重新启动&#xff0c;重启浏览器 第四步&#xff1a;开始注册 第五步&#xff0c;成功登录google账号&#xff01; 如果出现这样的原因&…...

wp在本地做的网站 上传/自己建网站

夜光序言&#xff1a; 如果说真实是残酷的&#xff0c;谎言绝对是温柔的吧。 ——所以&#xff0c;温柔是谎言。 正文&#xff1a;改变参数值的函数 改变参数值的函数  函数通过参数与调用程序传递信息。  例子1&#xff1a;银行账户计算利率  账户余额计算利息的函数…...

本网站建设中/短视频培训要多少学费

0、 【创建更新查询&#xff0c;选择经费字段—更新到设置为&#xff1a; [经费]2000 】1、 070101&#xff1a;将学生"入校时间"字段的默认值设置为下一年度的一月一日(规定&#xff1a;本年度的年号必须用函数获取)。2、 【设计视图—入校时间—默认值属性设置为&…...

男女做那个视频的网站/今日国内新闻头条

声明&#xff1a;此篇文章是个人学习笔记&#xff0c;并非教程&#xff0c;所以内容可能不够严谨。可作参考&#xff0c;但不保证绝对正确。如果你发现我的文章有什么错误&#xff0c;非常欢迎指正&#xff0c;谢谢哦 一、组件简介 CharacterContoller组件常用于第三人称或第…...

做动漫网站的素材/下载一个百度时事新闻

游戏规则:开局后系统后台随机生成四个0-9之间的数字,玩家每次输入四个数字,中间以空格隔开,如果玩家输入的数字中位置和数字全对,则显示4A,玩家获胜,如果只是数字正确但位置对,相应的用B表示,如果数字和位置都不对,则不显示任何,例如玩家输入了1234回车后显示的是1A2…...

wordpress建站简单吗/网站超级外链

...

阿里巴巴专门做外贸的网站/电脑速成班短期电脑培训班

Tuplestore模块处理元组的临时存储&#xff0c;用于Materialize节点、hashjoin批处理文件等。它本质上是tuplesort.c的简化版本&#xff1b;它不对元组进行排序&#xff0c;而只能存储和反刍(regurgitate)一系列元组。但是&#xff0c;因为不需要排序&#xff0c;所以允许在序列…...