python re正則表達式模塊(Regular Expression)
模塊的的作用主要是用于字符串和文本處理,查找,搜索,替換等
復習一下基本的正則表達式吧
.:匹配除了換行符以為的任意單個字符
*:匹配任意字符,一個,零個,多個都能匹配得到 俗稱貪婪模式
+:匹配位于+之前的一個或者多個字符
|:匹配位于|之前或者之后的字符
^:匹配行首
$:匹配行尾
?:匹配位于?之前的零個或者一個字符,不匹配多個字符
\:表示 \ 之后的為轉(zhuǎn)義字符
[]:匹配[]之中的任意單個字符,[0-9]表示匹配0到9任意一個數(shù)字
():將位于()之內(nèi)的的內(nèi)容當作一個整體
{}:按{}中的次數(shù)進行匹配,100[0-9]{3}表示在100之后任意匹配一個3位數(shù)(100-999)
python中以\開頭的元字符:
特殊序列符號 |
意義 |
\A |
只在字符串開始進行匹配 |
\Z |
只在字符串結(jié)尾進行匹配 |
\b |
匹配位于開始或結(jié)尾的空字符串 |
\B |
匹配不位于開始或結(jié)尾的空字符串 |
\d |
相當于[0-9] |
\D |
相當于[^0-9] |
\s |
匹配任意空白字符:[\t\n\r\r\v] |
\S |
匹配任意非空白字符:[^\t\n\r\r\v] |
\w |
匹配任意數(shù)字和字母:[a-zA-Z0-9] |
\W |
匹配任意非數(shù)字和字母:[^a-zA-Z0-9] |
正則表達式語法表
語法 | 意義 | 說明 |
"." | 任意字符 | |
"^" | 字符串開始 | '^hello'匹配'helloworld'而不匹配'aaaahellobbb' |
"$" | 字符串結(jié)尾 | 與上同理 |
"*" |
0 個或多個字符(貪婪匹配) |
<*>匹配<title>chinaunix</title> |
"+" |
1 個或多個字符(貪婪匹配) |
與上同理 |
"?" |
0 個或多個字符(貪婪匹配) |
與上同理 |
*?,+?,?? |
以上三個取第一個匹配結(jié)果(非貪婪匹配) | <*>匹配<title> |
{m,n} |
對于前一個字符重復m到n次,{m}亦可 |
a{6}匹配6個a、a{2,4}匹配2到4個a |
{m,n}? |
對于前一個字符重復m到n次,并取盡可能少 |
‘a(chǎn)aaaaa'中a{2,4}只會匹配2個 |
"\\" |
特殊字符轉(zhuǎn)義或者特殊序列 | |
[] |
表示一個字符集 | [0-9]、[a-z]、[A-Z]、[^0] |
"|" |
或 | A|B,或運算 |
(...) |
匹配括號中任意表達式 | |
(?#...) |
注釋,可忽略 | |
(?=...) |
Matches if ... matches next, but doesn't consume the string. |
'(?=test)' 在hellotest中匹配hello |
(?!...) |
Matches if ... doesn't match next. |
'(?!=test)' 若hello后面不為test,匹配hello |
(?<=...) |
Matches if preceded by ... (must be fixed length). |
'(?<=hello)test' 在hellotest中匹配test |
(?<!...) |
Matches if not preceded by ... (must be fixed length). |
'(?<!hello)test' 在hellotest中不匹配test |
匹配的標志和含義
標志 | 含義 |
re.I | 忽略大小寫 |
re.L | 根據(jù)本地設(shè)置而更改\w,\W,\b,\B,\s,\S的匹配內(nèi)容 |
re.M | 多行匹配模式 |
re.S | 使“.”元字符匹配換行符 |
re.U | 匹配Unicode字符 |
re.X | 忽略需要匹配模式中的空格,并且可以使用"#"號注釋 |
文本內(nèi)容(提取Linux下的password文件)
man:x:6:12:man:/var/cache/man:/bin/nologin
re模塊中有3個搜索函數(shù),每個函數(shù)都接受3個參數(shù)(匹配模式,要匹配的字符串,進行匹配的標志),如果匹配到了就返回一個對象實例,么有就返會None.
findall():用于在字符串中查找符合正則表達式的字符串,并返回這些字符串的列表
search():搜索整個字符串,返回對象實例
match():只從第一個字符開始匹配,后面的不再匹配,返回對象實例
lovelinux@LoveLinux:~/py/boke$ cat text man:x:6:12:man:/var/cache/man:/bin/sh lovelinux@LoveLinux:~/py/boke$ cat test.py #/usr/bin/env python #coding:utf-8 import re with open('text','r') as txt: f = txt.read() print re.match('bin',f) print re.search('bin',f).end() lovelinux@LoveLinux:~/py/boke$ python test.py None 34 lovelinux@LoveLinux:~/py/boke$ vim test.py lovelinux@LoveLinux:~/py/boke$ python test.py None <_sre.SRE_Match object at 0x7f12fc9f9ed0>
返回是對象實例有2個方法,
start():返回記錄匹配到字符的開始索引
end():返回記錄匹配到字符的結(jié)束索引
lovelinux@LoveLinux:~/py/boke$ python test.py None 31 34 lovelinux@LoveLinux:~/py/boke$ cat test.py #/usr/bin/env python #coding:utf-8 import re with open('text','r') as txt: f = txt.read() print re.match('bin',f) print re.search('bin',f).start() print re.search('bin',f).end()
相關(guān)文章
Python緩存方案優(yōu)化程序性能提高數(shù)據(jù)訪問速度
Python緩存方案是一種優(yōu)化程序性能,提高數(shù)據(jù)訪問速度的方案。通過緩存數(shù)據(jù),可以減少重復的計算和IO操作,從而提高程序的運行效率。Python中常用的緩存方案包括內(nèi)存緩存、磁盤緩存和分布式緩存等,根據(jù)實際需求選擇不同的方案可以幫助我們更好地優(yōu)化程序性能2023-05-05Django REST framework 如何實現(xiàn)內(nèi)置訪問頻率控制
這篇文章主要介紹了Django REST framework 內(nèi)置訪問頻率控制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07pycharm部署django項目到云服務(wù)器的詳細流程
今天重點給大家介紹pycharm部署django項目到云服務(wù)器的詳細流程,首先大家需要先下載python3.8壓縮包,然后通過一系列命令完成操作,具體實現(xiàn)方法,跟隨小編一起看看吧2021-06-06matplotlib.pyplot.matshow 矩陣可視化實例
這篇文章主要介紹了matplotlib.pyplot.matshow 矩陣可視化實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06