京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 2314|回复: 0

Python正则表达式保姆式教学详细教程

[复制链接]

22

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2021-11-15 07:42:33 | 显示全部楼层 |阅读模式 来自 中国
目录
9 t" ?4 p3 V/ r. q
5 {3 m5 y" ~' @9 t/ _; g

    ( ?  e/ Y: _7 N; Q1 O
  • 一、re模块
    ; D7 q; N0 ?1 c3 |5 A
      & `) u6 U( m( M( W9 l
    • 1.导入re模块: c8 U; b0 b7 p* `- A
    • 2.findall()的语法:
      % {& X7 c6 }2 c) x' D

    " {. W7 p$ K, X
  • 二、正则表达式
    5 a5 p5 g0 t1 p) o

      ; e: I/ K' G5 Y3 j4 C
    • 1.普通字符
      / ?8 y0 B+ K8 d6 n; z
    • 2.元字符
      : V2 O! j! Q, P& Q9 O1 y6 M
    ) f9 `/ d9 }" |) M- T1 a
  • (二)正则的使用% t( _) B  P# O( E& r. I$ R7 c
      . Q  Z" Z" {  U" {6 K- [, |5 w
    • 1.编译正则
      3 I3 O0 n! a+ u$ o3 ]  u* J9 I7 J& f
    • 2.正则对象的使用方法
      1 O) |# \/ O3 `
    • 3.Match object 的操作方法9 k+ J. ?0 R/ z
    • 4.re模块的函数% n  h# R2 I, R6 d8 N0 v5 w
    $ X+ q. y) x7 c  Q
正则作为处理字符串的一个实用工具,在Python中经常会用到,比如爬虫爬取数据时常用正则来检索字符串等等。正则表达式已经内嵌在Python中,通过导入re模块就可以使用,作为刚学Python的新手大多数都听说”正则“这个术语。
  I# X, c  _  f今天来给大家分享一份关于比较详细的Python正则表达式宝典,学会之后你将对正则表达式达到精通的状态。2 y8 ^4 @7 j, u$ M2 _
% Z% T8 ^/ F7 ?
! X$ w3 I: J# \
一、re模块
3 L; v; s: L$ J. s. U, ?$ t5 y7 T( o
在讲正则表达式之前,我们首先得知道哪里用得到正则表达式。正则表达式是用在findall()方法当中,大多数的字符串检索都可以通过findall()来完成。! |6 q" z2 I5 v
% x% g0 v' @3 }' e8 x% h: \
1.导入re模块3 b+ {, z# l4 G. f- Q9 d0 r+ C" i

" r/ t' o; S5 A3 o% \3 i; [. X/ b% W( |+ N4 Y/ V  E) I  p6 U
在使用正则表达式之前,需要导入re模块。
( Z7 y3 a! [% S$ ^+ w
import re ; p1 V7 p) U- a
- |( t( _* x: `5 P
2.findall()的语法:
/ l2 T/ Y4 {$ M( y" X: U3 ?# P0 k* v3 Y' K0 U* E% X) K7 R7 }
导入了re模块之后就可以使用findall()方法了,那么我们必须要清楚findall()的语法是怎么规定的。
& h; k/ I& _* z- b  d1 `3 |
findall(正则表达式,目标字符串)
0 B6 |% H) ]0 E' E# v
不难看出findall()的是由正则表达式和目标字符串组成,目标字符串就是你要检索的东西,那么如何检索则是通过正则表达式来进行操作,也就是我们今天的重点。0 g, t( z2 F# |6 c4 k; {" @
使用findall()之后返回的结果是一个列表,列表中是符合正则要求的字符串
  Z' F/ [; B3 C4 ~( B
  J: z# W' l( ~2 G* B二、正则表达式
: `% T% J& u0 t$ Y* p5 r7 y8 V
! q" y1 f% j) }4 E8 p# C(一).字符串的匹配
/ x9 n6 l: ^2 p8 u+ c/ C) T/ `  B# `
, y! |6 g2 \2 j! V, q4 v( G9 J1.普通字符
$ X/ d- J) U# ?5 N' _/ v- o+ s3 j
4 G$ I9 ~1 m; ^" h, r0 {4 ?

: S* {' K. h% L& P大多数的字母和字符都可以进行自身匹配。
  1. import rea = "abc123+-*"b = re.findall('abc',a)print(b)
复制代码
输出结果:
9 d5 W4 M( T+ O- a" K9 a5 P9 ]
['abc']8 y5 P9 s" a7 G2 `# c
/ p& j7 o; d+ a
2.元字符6 K% W! ]' V) {0 H3 v

* b$ a5 N* L5 n$ e; s0 P& Q元字符指的是. ^ $ ? + {} \ []之类的特殊字符,通过它们我们可以对目标字符串进行个性化检索,返回我们要的结果。
' P* K  @$ r  P  M7 G这里我给大家介绍10个常用的元字符以及它们的用法,这里我先给大家做1个简单的汇总,便于记忆,下面会挨个讲解每一个元字符的使用。: C1 u+ z, ^  r4 _% a3 W% n
: l% Y6 k/ P& r9 x
(1) []# X5 _6 \% ~0 D  T  @
[] 的使用方式主要有以下三种:
+ e1 h1 Q# R8 M! G常用来指定一个字符集。
  1. s = "a123456b"rule = "a[0-9][1-6][1-6][1-6][1-6][1-6]b"        #这里暂时先用这种麻烦点的方法,后面有更容易的,不用敲这么多[1-6]l = re.findall(rule,s)print(l)
复制代码
输出结果为:( I9 M. p) X( ?7 ~. D# F! i
['a123456b']
  [( ?2 E$ @& J5 k* E4 f
可以表示一个范围。
/ \+ B: y: [; q; @1 {$ V例如要在字符串"abcabcaccaac"中选出abc元素:
  1. s = "abcabcaccaac"rule = "a[a,b,c]c"  # rule = "a[a-z0-9][a-z0-9][a-z0-9][a-z0-9]c"        l = re.findall(rule, s)print(l)
复制代码
输出结果为:
' [" N8 e" j, Q8 @. V/ Y
['abc', 'abc', 'acc', 'aac']
* s; b; Q7 ?8 y+ }  w' M- ^1 ]
[] 内的元字符不起作用,只表示普通字符。  R4 |+ {% I: a4 @" |6 _& I
例如要在字符串“caabcabcaabc”中选出“caa”:
  1. print(re.findall("caa[a,^]", "caa^bcabcaabc"))
复制代码
输出结果为:
! W' U% v0 g+ `8 o  e1 P4 l% e
['caa^']
& x. p6 Q: R# O: ]' h
注意点:当在[]的第一个位置时,表示除了a以外的都进行匹配,例如把[]中的和a换一下位置:
  1. print(re.findall("caa[^,a]", "caa^bcabcaabc"))
复制代码
输出:
8 x8 n6 p/ `1 A& X! J+ ^
['caa^', 'caab']5 W% m# _6 o0 |) \3 l) t; F
(2)^  B" k6 w& }( H3 u. Q, ?
^ 通常用来匹配行首,例如:
  1. print(re.findall("^abca", "abcabcabc"))
复制代码
输出结果:- ~8 s7 V5 r2 F+ X
['abca']
8 g* X! N3 R2 @. f

* ]8 P# ~- u. \9 Z! Q3 W(3) $, E" J# F$ ^- ~% p
$ 通常用来匹配行尾,例如:
  1. print(re.findall("abc$", "accabcabc"))
复制代码
输出结果:. B2 G5 F! M6 _) c$ \1 I; P! x
['abc']
0 U$ U' t0 `: Z3 \+ \  b
' ?2 u/ n3 ~, f
(4)\' K; T% N1 ~+ [2 u) z& R/ r( e* t7 g
​ 反斜杠后面可以加不同的字符表示不同的特殊含义,常见的有以下3种。
" D. z9 s5 ?* T+ Q: Q\d:匹配任何十进制数等价于[0-9]
  1. print(re.findall("c\d\d\da", "abc123abc"))
复制代码
输出结果为:
/ T" A. x6 V7 ?+ b
['c123a']
; C& d+ G1 l( C* D3 [
\可以转义成普通字符,例如:
  1. print(re.findall("\^abc", "^abc^abc"))
复制代码
输出结果:" d. a5 W4 Y( K3 m4 L7 `
['^abc', '^abc']9 W4 D8 m# T7 V% ]0 Z
s- W$ P- j2 G" M: ?, U. Q
匹配任何的空白字符例如:
  1. print(re.findall("\s\s", "a     c"))
复制代码
输出结果:* x; y0 R  c4 X+ h9 s4 F% [
['  ', '  ']
  S1 L, I  G: W+ R8 t
\w) t( v. H9 |( \8 G8 p: `6 D1 e
匹配任何字母数字和下划线,等价于[a-zA-Z0-9_],例如:
  1. print(re.findall("\w\w\w", "abc12_"))
复制代码
输出:, M' T( q& `9 z7 j  x2 d
['abc', '12_']$ [  N( m1 \" Q! \! ^
$ R+ M" x9 ~( T. |
(5){n}2 K1 }$ ]0 q: K1 G& L& _
{n}可以避免重复写,比如前面我们用\w时写了3次\w,而这里我们这需要用用上{n}就可以,n表示匹配的次数,例如:
  1. print(re.findall("\w{2}", "abc12_"))
复制代码
输出结果:
! O% j. p$ _& V: ]( p
['ab', 'c1', '2_']
2 w' k- D; i1 W( W2 _) L
(6)*- F* q( s  E# P+ d0 G: Y. ]& t) Q2 J
*表示匹配零次或多次(尽可能的多去匹配),例如:
  1. print(re.findall("010-\d*", "010-123456789"))
复制代码
输出:" g+ e' \- c5 T$ P) ^8 _! {. |
['010-123456789']  k3 j/ Q7 P: J3 m
**(7) + **
5 [, H: ?5 [+ C6 W& p: G1 I& @# O+表示匹配一次或多次,例如
  1. print(re.findall("010-\d+", "010-123456789"))
复制代码
输出:" M* Y; u4 r3 _: U6 V2 t7 |4 }, C3 N
['010-123456789']% c. o, d5 `+ n& e! v
(8) .
3 @8 Y' y, u% H5 m1 w* S.是个点,这里不是很明显,它用来操作除了换行符以外的任何字符,例如:
  1. print(re.findall(".", "010\n?!"))
复制代码
输出:
, b! o/ h/ T4 w7 ^7 F4 V; _- j
['0', '1', '0', '?', '!']6 H6 q1 @" |$ k
(9) ?* J( h9 `$ J' b" P5 F9 @) j( l
?表示匹配一次或零次
  1. print(re.findall("010-\d?", "010-123456789"))
复制代码
输出:) M+ S  y! s8 q/ I/ _
['010-1']
% `9 V( b" N" ^, s
这里要注意一下贪婪模式和非贪婪模式。
0 V$ ?1 X' q$ p, e: s- B" F; C- u贪婪模式:尽可能多的去匹配数据,表现为\d后面加某个元字符,例如\d*:
  1. print(re.findall("010-\d*", "010-123456789"))
复制代码
输出:
! f8 p$ c/ g- L$ V# }
['010-123456789']
' W' K$ k, P+ Y8 ~
非贪婪模式:尽可能少的去匹配数据,表现为\d后面加?,例如\d?
  1. print(re.findall("010-\d*?", "010-123456789"))
复制代码
输出为:, R6 P# U3 \: e: C5 q) H
['010-']% M9 @6 t+ b7 M8 c0 D
(10){m,n}
0 f: G) Y* z1 i. v. m1 j: Bm,n指的是十进制数,表示最少重复m次,最多重复n次,例如:
  1. print(re.findall("010-\d{3,5}", "010-123456789"))
复制代码
输出:
+ a6 r5 p9 _  g) q7 }  I
['010-12345']; s5 V6 b" D9 P5 A
加上?表示尽可能少的去匹配
  1. print(re.findall("010-\d{3,5}?", "010-123456789"))
复制代码
输出:1 f5 X( V6 y5 @* f+ H
['010-123']
$ \" U; f" C/ ?9 x9 `
{m,n}还有其他的一些灵活的写法,比如:
6 r% Z( f' c7 X5 l/ V+ {" v
       
    & }% o) K6 i8 T; g
  • {1,} 相当于前面提过的 + 的效果   
    / m+ d' G  K( N% c' b% n" f  ?9 E7 A
  • {0,1} 相当于前面提过的 ? 的效果   
    , Y+ Q4 z6 ?& e4 L5 `
  • {0,} 相当于前面提过的 * 的效果
    ; R( [: D' `7 k- M

: {7 C; \% v# A  F8 G  [关于常用的元字符以及使用方法就先到这里,我们再来看看正则的其他知识。
) M2 t' m- |0 C- m3 [8 s8 v

5 I- u/ ~# v0 G$ S& P) A+ s(二)正则的使用6 [2 R. ]% z& K& E1 z

4 e4 o$ D# M$ a3 e! q% k8 g. c0 O4 C4 E
1.编译正则# y7 T3 Q1 C2 H; E/ G1 j
1 K. b1 G, }5 K- S8 e; B
在Python中,re模块可通过compile() 方法来编译正则,re.compile(正则表达式),例如:
  1. s = "010-123456789" rule = "010-\d*" rule_compile = re.compile(rule) #返回一个对象 # print(rule_compile) s_compile = rule_compile.findall(s) print(s_compile)        #打印compile()返回的对象是什么
复制代码
输出结果:! y" _! v/ D( U4 U" D- K
['010-123456789']* C: Q1 T8 x9 q6 d, F, N& A9 D

( {9 I- s; t: d0 U# J5 K2.正则对象的使用方法& l. S6 E) o1 t* k% A  ~

& L, z  I, @5 O正则对象的使用方法不仅仅是通过我们前面所介绍的 findall() 来使用,还可以通过其他的方法进行使用,效果是不一样的,这里我做个简单的总结:
! y0 ]  B7 C/ O(1)findall(); T  E* B0 ?" _: i6 T
找到re匹配的所有字符串,返回一个列表
$ M7 Q+ [9 N% b* Y- O0 U(2)search()
  Y; s9 ^! p& H扫描字符串,找到这个re匹配的位置(仅仅是第一个查到的)
' ?; ^' ^& x! ~2 Y; d9 N(3)match()
+ s* s1 A2 S# p+ \2 Y7 U' A, A  l决定re是否在字符串刚开始的位置(匹配行首)
1 t' p/ `4 U/ ]1 a! t就拿上面的 compile()编译正则之后返回的对象来做举例,我们这里不用 findall() ,用 match() 来看一下结果如何:
  1. s = "010-123456789"rule = "010-\d*"rule_compile = re.compile(rule)  # 返回一个对象# print(rule_compile)s_compile = rule_compile.match(s)print(s_compile)  # 打印compile()返回的对象是什么
复制代码
输出:
& e/ W4 y0 ]7 v( p5 a( [7 r  V
- p7 D' I1 w' d8 O
可以看出结果是1个match 对象,开始下标位置为0~13,match为 010-123456789 。既然返回的是对象,那么接下来我们来讲讲这个match 对象的一些操作方法。
8 e( c" `1 X1 v! i2 Q

" @9 |3 j/ F! k! W! ]0 E* H! ^% h2 D
, [# j& T) D/ d8 ?$ v3.Match object 的操作方法
  I+ L7 ?4 h& x3 n/ e0 l! I: t
这里先介绍一下方法,后面我再举例,Match对象常见的使用方法有以下几个:
; z% Q5 W" Z1 o+ J8 m* Y0 C4 p' v(1)group()0 Z4 }$ B- A# a$ j; C* R( b/ J) F4 Y! a
返回re匹配的字符串
5 B! |* Y6 ~9 N0 I& M$ A0 X) d3 P(2)start()
+ m- s& p1 ~  u( s; l返回匹配开始的位置
, u" R- @4 ^/ l" I) Z- d1 E(3)end()
  ^. m9 R, d+ ~  p% V* D' H返回匹配结束的位置" E6 H' ^7 N9 |) h& l) d, {2 j
(4)span()1 i4 v* D+ J6 Z" a3 H" E
返回一个元组:(开始,结束)的位置# z7 O: }5 q( t0 F$ x: n6 x% N; O
举例:用span()来对search()返回的对象进行操作:
  1. s = "010-123456789"rule = "010-\d*"rule_compile = re.compile(rule)  # 返回一个对象s_compile = rule_compile.match(s)print(s_compile.span())  #用span()处理返回的对象
复制代码
结果为:3 Y5 I( ^5 }2 w0 S( y' I# x
(0, 13), T6 `3 `* Z4 f! f% s
# S, A9 x! I, t& }/ y, X
4.re模块的函数# s) q$ D: Z, K9 y

- X% \# h6 o& w! L; A4 T3 Kre模块中除了上面介绍的findall()函数之外,还有其他的函数,来做一个介绍:
8 y+ n+ K- Y" ~8 f(1)findall()4 L! x  t7 ^# M  }6 x
根据正则表达式返回匹配到的所有字符串,这个我就不多说了,前面都是在介绍它。8 e  z% l) M4 o% d/ L$ _
(2)sub(正则,新字符串,原字符串)
2 k6 t' G! Q; }" O+ Z# Jsub() 函数的功能是替换字符串,例如:
  1. s = "abcabcacc" #原字符串l = re.sub("abc","ddd",s)   #通过sub()处理过的字符串print(l)
复制代码
输出:0 G$ [: k- ^$ G/ I2 V- |3 W# o% S: H  E4 n
ddddddacc #把abc全部替换成ddd
) C, u7 W3 u' z
(3)subn(正则,新字符串,原字符串)5 L% {0 F) l% g+ T
subn()的作用是替换字符串,并返回替换的次数
  1. s = "abcabcacc" #原字符串l = re.subn("abc","ddd",s)   #通过sub()处理过的字符串print(l)
复制代码
输出:
% e  q$ P4 Y/ X7 T( |& E
('bbbbbbacc', 2)  Z( Z: Q5 X3 V+ ?3 ^/ \0 R
(4)split(); g; e' U7 }1 S
split()分割字符串,例如:
  1. s = "abcabcacc"l = re.split("b",s)print(l)
复制代码
输出结果:) k1 X  t8 c1 V0 E; f) n. h* @
['a', 'ca', 'cacc']
5 h2 x+ I+ W( h, O# X) R( q
4 [3 m5 O# M% }: R3 `0 |
关于正则,我就讲这么多了,正则几乎是Python所有方向中是必不可少的一个基础,祝你的Python之旅学有所成!9 J; x4 R& k- C
到此这篇关于Python正则表达式保姆式教学详细教程的文章就介绍到这了,更多相关Python正则表达式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
6 g1 H  G: h" c+ F- I3 L" u8 h. M0 g7 P/ ^
来源:http://www.jb51.net/article/221286.htm
+ i; O: X- t& {5 g2 c免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2026-3-24 00:17 , Processed in 0.042747 second(s), 24 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表