前言: 这篇文章主要想讲解一下python中的正则表达式: 1,什么是正则表达式 2,re模块三匹配 3,元字符匹配 4,具体示例

个人简介:努力学习ing 个人专栏:C语言入门基础以及python入门基础 CSDN主页 愚润求学 每日鸡汤:天生我材必有用,千金散尽还复来

文章目录

一,什么是正则表达式二,re模块三匹配1,match()2,search()3,findall()4,总结

三,元字符匹配1,单字符匹配2,数量匹配3,边界匹配四,具体示例例一例二例三

一,什么是正则表达式

正则表达式(Regular Expression)是一种用于处理字符串的强大工具,它可以用来检查字符串是否符合某种模式、提取字符串中的特定部分或者替换字符串中的某些内容。 比如在某些场景,我们在输入邮箱的时候,如果我们的输入不符合邮箱地址的规则,则会被提示错误输入。

二,re模块三匹配

下面是三种常用来匹配的函数

1,match()

match()函数用于从字符串的开头开始匹配正则表达式。(如果第一个字符就不匹配则直接返回None) 如果匹配成功,返回一个匹配对象(包含匹配的信息);如果匹配失败,返回None。

函数原型:

re.match(pattern, string, flags=0)

pattern: 匹配的正则表达式(匹配规则) string: 要匹配的字符串 flags: 可选参数,用于控制匹配方式,如是否忽略大小写、是否多行匹配等。

示例:

import re

a = "hello world! hello world."

print(re.match('hello', a))

输出: (这个span(0,5)是不包括5下标的)

2,search()

search()函数用于在字符串中搜索与正则表达式匹配的子字符串。如果找到匹配项,返回一个匹配对象;如果找不到匹配项,返回None。

函数原型:

re.search(pattern, string, flags=0)

(参数与match()相同。)

示例:

import re

a = "hello world! hello world."

print(re.search('llo', a))

输出:

3,findall()

findall()函数用于在字符串中查找所有与正则表达式匹配的子字符串,并返回一个包含所有匹配项的列表。 函数原型:

re.findall(pattern, string, flags=0)

(参数与match()和search()相同。)

示例:

import re

a = "hello world! hello world."

print(re.findall('llo', a))

输出:

4,总结

●match(): 从字符串的开头开始匹配,如果开头不匹配则返回None。匹配成功则返回第一个匹配项(包含信息),匹配失败则返回None ●search(): 在字符串中搜索与正则表达式匹配的子字符串,返回第一个匹配项(包含信息),失败返回None。 ●findall(): 在字符串中查找所有与正则表达式匹配的子字符串,并返回一个包含所有匹配项的列表,找不到则返回一个空列表。

三,元字符匹配

正则表达式的核心是用于构建模式的元字符。元字符是一些具有特殊含义的字符,可以用来匹配某一类字符。使用元字符构建一个模式,然后使用这个模式来处理字符串。

为了创建一个正则表达式,你通常需要在字符串前面添加一个r前缀。这个前缀告诉Python解释器这是一个原始字符串(raw string)

1,单字符匹配

2,数量匹配

如:\d*:匹配0个或者无数个数字 [0-9]+:匹配1个或者无数个0-9之间的数字) [^0]:匹配除了0以外的所有字符 [^a-zA-Z]:匹配除了字母a-z和A-Z以外的所有字符。(a-z和A-Z之间最好不要加,) 注意:{m,n}之间不要加逗号:a{1,2},b{1,3}【错误的】

3,边界匹配

^[0-9]+$:从头开始匹配到结尾,中间出现1个或无数个0-9之间的数字 ():把()内要匹配的当一个整体来匹配 | :意思就是或,如:com|136|qq就是指这里匹配com或者136或者qq

四,具体示例

例一

匹配账号,只能由字母和数字组成,长度限制6到10位:

principle1 = r'^[0-9a-zA-Z]{6,10}$'

示例:

import re

principle1 = r'^[0-9a-zA-Z]{6,10}$'

text1 = "2005abc"

text2 = "200504@abc"

match_obj1, match_obj2 = re.match(principle1, text1), re.match(principle1, text2)

print(f"text1匹配的结果是:{match_obj1}\ntext2匹配的结果是{match_obj2}")

输出结果:

例二

匹配QQ号,要求纯数字,长度5-11,第一位不为0:

principle2 = r'^[1-9][0-9]{4,10}$'

例三

匹配邮箱地址 要求: 1,邮箱地址的格式:用户名+@+域名 2,用户名是由数字、字母、_或-组成 3,只允许qq、163、gmail这三种邮箱地址

提示: 如126.com是域名,.edu.com也是域名……

答案:

principle3 = r'^[\w-]+(\.[\w-]+)*@(qq|163|gmail)(\.[\w-]+)+$'

[\w-]+ 表示出现a-z A-Z 0-9 _ 和 - 字符最少1个,最多不限 (\.[\w-]+)*,表示出现组合 . 和 a-z A-Z 0-9 _ -的组合最少0次,最多不限 用于匹配如:abc.def@…… @表示匹配@符号 (qq|163|gmail)表示只匹配这3个邮箱提供商 (\.[\w-]+)+表示组合 . 和 a-z A-Z 0-9 _ -的组合最少1次,最多不限 如:3369134@abc.def.com

我的分享也就到此结束啦 要是我的分享也能对你的学习起到帮助,那简直是太酷啦! 若有不足,还请大家多多指正,我们一起学习交流! 公主,王子:点赞→收藏⭐→关注 感谢大家的观看和支持!祝大家都能得偿所愿,天天开心!!!

好文推荐

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: