正则表达式学习(一)

一 正在表达式的概述

1、正则表达式

正则表达式描述了一种字符串匹配的模式,可以检查一个字符串是否含有某种子字符串,将匹配到的子字符串用来提取出来或者做替换。

模式:使用一种特殊符号来实现字符串的匹配。

本文以javascript来阐述正则表达式的基础知识和使用

功能:使用一种特殊符号来实现字符串的匹配

var  reg = /\d/gi;

mysql如何匹配:

① 精准匹配 :select * from goods where title=’iphone 7 plus’;  //一条

② 模糊匹配 :select * from goods where title like ‘%iphone 7 plus%’;  //多条

2、为什么要使用正则表达式

数据隐藏 (188********092张武功)

数据采集 (数据爬虫)

数据过滤 (数据敏感词过滤,比如一些侮辱性词语)

数据验证 (表单验证常用,比如 手机号验证、邮箱验证...)

3、快速入门

例1:查找一个字符串中是否具有数字“8”(可以使用indexOf)

var a1 = 'ni shi ge hen shuai de ren';
var a2 = 'ni shi ge bu shuai de ren 12800,.....';
var reg = /8/gi
//1、 test() 检测子字符串是否存在,返回boolean值
console.log(reg.test(a1))
/* 结果false */
console.log(reg.test(a2))
/* 结果true */

例2:查找一个字符串中是否具有数字(数字是从0-9,可以使用charAt)

var a1 = "xiyangyang";
var a2 = "xiyangyang2";
var reg = /\d/gi
reg.test(a1); /* 结果false */
reg.test(a2); /* 结果true */

例3:查找一个字符串中是否具有非数字

var b1 = "zhongguo";
var b2 = "zhongguonihaoa10-01";
var reg = /\D/i;
reg.test(b1);
/* 结果true */
reg.test(b2);
/* 结果true */

二、正则对象

1、为什么要使用正则对象呢?

在实际应用中,要使用正则表达式必须有一个前提,首先要创建正则对象

2、创建正则对象

①隐式创建

var 正则对象 = /正则表达式/匹配模式

②直接实例化

var 正则对象 = new RegExp('正则表达式', '匹配模式')

问题:隐式创建与直接实例化有什么区别呢?

答:两者之间的功能是完全一致的,都是为了获得正则对象。但是两者之间的区别主要在于语法的不同。

例:求三位连续的数字

隐式创建:

var reg = /\d\d\d/gi;

直接实例化

var reg = new RegExp('\\d\\d\\d');

由以上代码可知,两者功能完全一致,唯一区别在于语法的不同,直接实例化RegExp中,正则表达式需要对反斜杠 \进行转义操作

var a = "123abc567cvs";
var reg = new RegExp('\\d\\d\\d','gi');
reg.test(a);
//结果true

3、匹配模式

基础语法

var reg = /正则表达式/匹配模式
g:global缩写,代表全局匹配,匹配出所有满足条件的结果
i: ignore缩写,代表忽略大小写,匹配时,会自动忽略字符串的大小

示例代码

var str = "abcdefg"
var reg = /cde/gi
console.log(reg.test(str))
/*结果true*/

4、 与正则表达式相关的几个方法

① RegExp类下的方法(reg.test或 reg.exec)

test(str):判断字符串中是否具有指定模式的子字符串,返回结果是一个布尔类型的值

exec(str):返回字符串中指定模式的子字符串,一次只能获取一个与之匹配的结果

示例


    <!--一个输入框和两个按钮-->

    <!--引入jquery.js 不引入的可写原生js-->

          /*获取btn1按钮并绑定点击事件*/

$("#btn1").onclick = function(){

                /*获取文本框的值*/

let content = $('#content').value;

                /*获取正则对象,规则三位挨着的数字*/

let reg = /\d\d\d/gi

                /*判断*/

alert(reg.test(content));

}

          /*获取btn2按钮并绑定点击事件*/

$("#btn2").onclick = function(){

              /*获取文本框的值*/

let content = $('#content').value;

              /*获取正则对象,规则三位挨着的数字*/

let reg = /\d\d\d/gi

              /*输出匹配到的数据*/

alert(reg.exec(content));

}

② String类下的方法(str.方法(reg))

String.search(reg):与indexOf非常类型,返回指定模式的子串在字符串中首次出现的位置。

String.match(reg):以数组的形式返回指定模式的字符串,可以返回所有的匹配的结果。

String.replace(reg, '替换后的字符'):把指定模式的子串进行替换操作。

String.split(reg):以指定模式分割字符串,返回结果为数组。

示例:使用以上方法查找字符串中三个连续数字


var str = "abcd345efg188vbncmd255hjak";

var reg = /\d\d\d/gi;

/*String.search(reg)  返回子串首次出现的位置*/

console.log(str.search(reg));/*结果: 4 */

/*String.match(reg)  返回所有匹配结果*/

console.log(str.match(reg));/*结果: ["345", "188", "255"] */

/*String.replace(reg)  返回所有匹配结果*/

console.log(str.replace(reg, '帅'));/*结果: abcd帅efg帅vbncmd帅hjak */

/*String.split(reg)  返回所有匹配结果*/

console.log(str.split(reg));/*结果: ["abcd", "efg", "vbncmd", "hjak"] */

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352