一文秒懂python正则表达式常用函数01 Re概览
Re模块是python的内置模块,提供了正则表达式在python中的所有用法 , 默认安装位置在python根目录下的Lib文件夹(如 ..\Python\Python37\Lib) 。主要提供了3大类字符串操作方法:
字符查找/匹配
字符替换
字符分割
由于是面向字符串类型的模块,就不得不提到字符串编码类型 。re模块中,模式串和搜索串既可以是 Unicode 字符串 (常用str类型),也可以是8位字节串 (bytes,2位16进制数字,例如\xe5),但要求二者必须是同类型字符串 。
02 字符串查找/匹配
预编译:compile
在介绍查找和匹配函数前,首先需要知道re的compile函数,该函数可以将一个模式串编译成正则表达式类型,以便后续快速匹配和复用
import repattern = re.compile(r'[a-z]{2,5}')type(pattern) #re.Pattern
此例创建了一个正则表达式式对象 (re.pattern),命名为pattern,用于匹配2-5位小写字母的模式串 。后续在使用其他正则表达式函数时,即可使用pattern进行方法调用 。
匹配:match
match函数用于从文本串的起始位置开始匹配,若匹配成功,则返回相应的匹配对象 , 此时可调用group()方法返回匹配结果,也可用span()方法返回匹配起止下标区间;否则返回None
import repattern = re.compile(r'[a-z]{2,5}')text1 = 'this is a re test'res = pattern.match(text1)print(res) #if res:print(res.group()) #thisprint(res.span()) #(0, 4)text2 = '是的, this is a re test'print(pattern.match(text2))#None
match函数还有一个变形函数fullmatch , 当且仅当模式串与文本串刚好全部匹配时,返回一个匹配对象,否则返回None
搜索:search
match只提供了从文本串起始位置匹配的结果 , 如果想从任意位置匹配 , 则可调用search方法,与match方法类似 , 当任意位置匹配成功,则立即返回一个匹配对象,也可调用span()方法获取起止区间、调用group方法获得匹配文本串
import repattern = re.compile(r'\s[a-z]{2}')text1 = 'this is a re test'res = pattern.search(text1)print(res) #if res:print(res.group()) #isprint(res.span()) #(4, 7)pattern2 = re.compile(r'\s[a-z]{5}')text2 = '是的,this is a re test'print(pattern2.search(text2))#None
match和search均用于匹配单个结果,唯一区别在于前者是从起始位置开始匹配,而后者从任意位置匹配,匹配成功则返回一个match对象 。
全搜索:findall/finditer
几乎是最常用的正则表达式函数,用于寻找所有匹配的结果,例如在爬虫信息提取中 , 可非常方便地提取所有匹配字段
import repattern = re.compile(r'\s[a-z]{2,5}')text1 = 'this is a re test'res = pattern.findall(text1)print(res) #[' is', ' re', ' test']
findall返回的是一个列表对象类型,当无匹配对象时,返回一个空列表 。为了避免因同时返回大量匹配结果占用过多内存,可以调用finditer函数返回一个迭代器类型,其中每个迭代元素是一个match对象,可继续调用group和span方法获取相应结果
import repattern = re.compile(r'\s[a-z]{2,5}')text1 = 'this is a re test'res = pattern.finditer(text1)for r in res:print(r.group())"""isretest"""
当匹配模式串较为简单或者仅需单词调用时,上述所有方法也可直接调用re类函数 , 而无需事先编译 。此时各方法的第一个参数为模式串 。
import repattern = re.compile(r'\d{2,5}')text = 'this is re test're.findall('[a-z]+', text) #['this', 'is', 're', 'test']03 字符串替换/分割
替换:sub/subn
当需要对文本串进行条件替换时,可调用re.sub实现 (当然也可先编译后再用调用实例方法) ,相应参数分别为模式串、替换格式、文本串,还可以通过增加缺省参数限定替换次数和匹配模式 。通过在模式串进行分组,可实现字符串的格式化替换(类似字符串的format方法) , 以实现特定任务 。
import retext = 'today is 2020-03-05'print(re.sub('-', '', text)) #'today is 20200305'print(re.sub('-', '', text, 1)) #'today is 202003-05'print(re.sub('(\d{4})-(\d{2})-(\d{2})', r'\2/\3/\1', text)) #'today is 03/05/2020'
re.sub的一个变形方法是re.subn,区别是返回一个2元素的元组,其中第一个元素为替换结果,第二个为替换次数
import retext = 'today is 2020-03-05'print(re.subn('-', '', text)) #('today is 20200305', 2)
分割:split
还可以调用正则表达式实现字符串的特定分割,相当于.split()方法的一个加强版 , 实现特定模式的分割,返回一个切割后的结果列表
import retext = 'today is a re test, what do you mind?'print(re.split(',', text)) #['today is a re test', ' what do you mind?']04 总结
python中的re模块提供了正则表达式的常用方法,每种方法都包括类方法调用(如re.match)或模式串的实例调用(pattern.match)2种形式
常用的匹配函数:match/fullmatch
常用的搜索函数:search/findall/finditer
常用的替换函数:sub/subn
常用的切割函数:split
还有其他很多方法 , 但不是很常用,具体可参考官方文档
另外,python还有第三方正则表达式库regex可供选择
到此这篇关于一文秒懂python正则表达式常用函数的文章就介绍到这了 , 希望大家以后多多支持!
python中print函数的用法python中print函数的用法是python常用函数用法:
第一种方法python常用函数用法:一个萝卜一个坑python常用函数用法,下面的代码中,{0}、{1}、{2}分别表示j,i,j*i , 单引号里面是输出格式 。
print('{0}+{1}={2}'.format(j,i,j+i)) 。
第二种方法:类似于C语言格式输出,使用%开头格式输出 。
print("%d + %d = %d" %(j,i,j+i)) 。
python中自动换行,要想不换行的话,需要在print括号最后面加上 , end = ''print(i, end = '' ) 。
Python常用格式字符是:
1、%s 字符串采用str()的显示 。
2、%x 十六进制整数 。
3、%r 字符串(repr())的显示 。
4、%e 指数(基底写e) 。
5、%c 单个字符 。
【python常用函数用法 python 常用的函数】6、%E 指数(基底写E) 。
7、%b 二进制整数 。
8、%f,%F 浮点数 。
9、%d 十进制整数 。
10、%g 指数(e)或浮点数(根据显示长度) 。
11、%i 十进制整数 。
12、%G 指数(E)或浮点数(根据显示长度) 。
13、%o 八进制整数 。
14、%% 字符% 。
Python常用函数三有哪些?这7个函数使用频率最高 , 总算搞明白了1.1 例如:print(hex(2))案例
1.2 输出函数:print(hex(2))
1.3 输出结果:0x2
1.4 解析说明:返回16进制的数 。
2.1 例如:print(chr(10))案例
2.2 输出函数:print(chr(10))
2.3 输出结果:0o12
2.4 解析说明:返回当前整数对应的ASCll码
3.1 例如:print(ord("b"))案例
3.2 输出函数:print(ord("b"))
3.3 输出结果:98
3.4 解析说明:返回当前ASCll码的10进制数
4.1 例如:print(chr(97))
4.2 输出函数:print(chr(97))
4.3 输出结果:b
4.4 解析说明:返回当前ASCll码的10进制数 。
案例一:给你一个字符串,s = 'hello kitty'
1.1 输出函数:print(s.capitalize())
1.2 输出结果:0x2
1.3 解析说明:返回16进制的数 。
2.1输出函数:print(s.replace('kitty','kuang'))
2.2 输出结果:hello kuang
2.3 解析说明:替换功能,将kitty换成kuang 。
2.4 输出函数:print(s.replace('4','KK'))
2.5 输出结果:12KK12KK
2.6 解析说明:所有的4都替换成KK
2.7 输出函数:print(s.replace('4','KK'))
2.8 输出结果:12KK12KK124
2.9 解析说明:将前两个的4替换成go
案例一:给你一个字符串,ip = '192.168.1.1'
3.1 输出函数:print(ip.split(','))
3.2 输出结果:['192.168.1.1']
3.3 解析说明:将字符串分割成列表
案例一:给你一个字符串,ip = '192.168.1.1'
3.3 输出函数:print(ip.split(',',2))
3.4 输出结果:['192.168.1.1']
3.5 解析说明:从第二个开始分割成列表
python 8个常用内置函数解说8个超好用内置函数set(),eval(),sorted(),reversed(),map(),reduce(),filter(),enumerate()
python中有许多内置函数,不像print那么广为人知,但它们却异常的强大 , 用好了可以大大提高代码效率 。
这次来梳理下8个好用的python内置函数
1、set()
当需要对一个列表进行去重操作的时候,set()函数就派上用场了 。
用于创建一个集合,集合里的元素是无序且不重复的 。集合对象创建后,还能使用并集、交集、差集功能 。
2、eval()之前有人问如何用python写一个四则运算器 , 输入字符串公式,直接产生结果 。用eval()来做就很简单:eval(str_expression)作用是将字符串转换成表达式,并且执行 。
3、sorted()在处理数据过程中,我们经常会用到排序操作,比如将列表、字典、元组里面的元素正/倒排序 。这时候就需要用到sorted(),它可以对任何可迭代对象进行排序 , 并返回列表 。对列表升序操作:
对元组倒序操作:
使用参数:key,根据自定义规则,按字符串长度来排序:
根据自定义规则,对元组构成的列表进行排序:
4、reversed()如果需要对序列的元素进行反转操作,reversed()函数能帮到你 。reversed()接受一个序列,将序列里的元素反转,并最终返回迭代器 。
5、map()做文本处理的时候,假如要对序列里的每个单词进行大写转化操作 。这个时候就可以使用map()函数 。
map()会根据提供的函数,对指定的序列做映射,最终返回迭代器 。也就是说map()函数会把序列里的每一个元素用指定的方法加工一遍,最终返回给你加工好的序列 。举个例子 , 对列表里的每个数字作平方处理:
6、reduce()前面说到对列表里的每个数字作平方处理,用map()函数 。那我想将列表里的每个元素相乘,该怎么做呢?这时候用到reduce()函数 。
reduce()会对参数序列中元素进行累积 。第一、第二个元素先进行函数操作,生成的结果再和第三个元素进行函数操作 , 以此类推,最终生成所有元素累积运算的结果 。再举个例子,将字母连接成字符串 。
你可能已经注意到,reduce()函数在python3里已经不再是内置函数,而是迁移到了functools模块中 。这里把reduce()函数拎出来讲,是因为它太重要了 。
7、filter()一些数字组成的列表 , 要把其中偶数去掉,该怎么做呢?
filter()函数轻松完成了任务 , 它用于过滤序列,过滤掉不符合条件的元素,返回一个迭代器对象 。filter()函数和map()、reduce()函数类似,都是将序列里的每个元素映射到函数,最终返回结果 。我们再试试 , 如何从许多单词里挑出包含字母w的单词 。
8、enumerate()这样一个场景,同时打印出序列里每一个元素和它对应的顺序号 , 我们用enumerate()函数做做看 。
enumerate翻译过来是枚举、列举的意思,所以说enumerate()函数用于对序列里的元素进行顺序标注,返回(元素、索引)组成的迭代器 。再举个例子说明,对字符串进行标注 , 返回每个字母和其索引 。
python中pos函数用法Pos()功能在一个字符串中查找所包含的另一个字符串的起始位置 。语法Pos ( string1,string2 {,start } )
参数string1:string类型,指定要从中查找子串string2的字符串string2:string类型,指定要在string1中查找的字符串start:long类型,可选项 , 指定从string1的第几个字符开始查找 。缺省值为1返回值Long 。函数执行成功时返回在start位置后string2在string1中第一次出现的起始位置 。如果在string1中按指定要求未找到string2、或start的值超过了string1的长度 , 那么Pos()函数返回0 。如果任何参数的值为NULL,Pos()函数返回NULL 。用法Pos()函数在字符串查找时区分大小写 , 因此,"aa"不匹配"AA" 。
拓展资料:
公式的运用
一、数字处理
1、取绝对值函数
公式:=ABS(数字)
2、取整函数
公式:=INT(数字)
3、四舍五入函数
公式:=ROUND(数字 , 小数位数)
二、判断公式
1、如果计算的结果值错误那么显示为空
公式:=IFERROR(数字/数字,)
说明:如果计算的结果错误则显示为空,否则正常显示 。
2、IF语句的多条件判定及返回值
公式:IF(AND(单元格(逻辑运算符)数值,指定单元格=返回值1),返回值2 , )
说明:所有条件同时成立时用AND , 任一个成立用OR函数 。
三、常用的统计公式
1、统计在两个表格中相同的内容
公式:B2=COUNTIF(数据源:位置 , 指定的 , 目标位置)
说明:如果返回值大于0说明在另一个表中存在,0则不存在 。
如果,在此示例中所用到的公式为:B2=COUNTIF(Sheet15!A:A , A2)
2、统计不重复的总数据
公式:C2=SUMPRODUCT(1/COUNTIF(A2:A8,A2:A8))
说明:用COUNTIF函数统计出源数据中每人的出现次数,并用1除的方式把变成分数,最后再相加 。
四、数据求和公式
1、隔列求和的应用
公式:H3=SUMIF($A$2:$G$2,H$2,A3:G3)或=SUMPRODUCT((MOD(COLUMN(B3:G3) , 2)=0)*B3:G3)
说明:如果在标题行中没有规则就可以用第2个公式
2、单条件应用之求和
公式:F2=SUMIF(A:A , C:C)
说明:这是SUMIF函数的最基础的用法
五、查找与引用公式
1、单条件查找
说明:VLOOKUP是excel中最常用的查找方式
六、字符串处理公式
1、多单元格字符串的合并
说明:Phonetic函数只能合并字符型数据 , 不能合并数值 。
2、截取结果3位之外的部分
说明:LEN计算总长度,LEFT从左边截总长度-3个 。
python中range()函数的用法python中range()函数的用法:
(1)range(stop)
创建一个(0,stop)之间的整数序列,步长为1 。
(2)range(start,stop)
创建一个(start,stop)之间的整数序列 , 步长为1 。
(3)range(start,stop,step)
创建一个[start,stop)之间的整数序列,步长为step 。
参数介绍:
start:表示从返回序列的起始编号,默认情况下从0开始 。
stop:表示生成最多但不包括此数字的数字 。
step:指的是序列中每个数字之间的差异,默认值为1 。
相关介绍
range()是Python的内置函数,在用户需要执行特定次数的操作时使用它,表示循环的意思 。内置函数range()可用于以列表的形式生成数字序列 。在range()函数中最常见用法是使用for和while循环迭代序列类型(List,string等) 。
简单的来说,range()函数允许用户在给定范围内生成一系列数字 。根据用户传递给函数的参数数量,用户可以决定该系列数字的开始和结束位置以及一个数字与下一个数字之间的差异有多大 。
关于python常用函数用法和python 常用的函数的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。
推荐阅读
- 山西如何网络推广优化,山西网站优化
- 视频号直播怎么连线别人,视频号直播怎么上链接卖货
- b站现在可以暂时直播吗,b站可以随便直播电视剧吗
- vb.net三角形 vb三角形代码
- 象棋什么时候开始用电脑,象棋什么时候开始用电脑的
- 鸿蒙系统桌面时间在哪设置,鸿蒙怎样设置桌面时间
- 家庭烘焙直播话术,烘培宣传视频
- 怎么把硬盘里系统删了呢,硬盘怎么删除系统
- 虎牙直播主播如何播放音乐,虎牙直播主播如何播放音乐的