麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Python > 正文

python 正則表達式學習小結

2020-03-22 20:24:31
字體:
來源:轉載
供稿:網友
在Python中實現正則的方式是通過re(regular expression的縮寫)模塊來實現的,你可以調用re模塊的各種方法來實現不同的功能,下面我們就來說下,在Python中通過re模塊可以調用那些方法,以及這些方法的作用都是什么;還有就是正則的實例以及各種特殊符號的含義:
1、re.sub和replace:
sub的全拼是substitute,也就是替換的意思;既然知道是替換了,那就很容易用到實例中了,其實replace也是替換的意思,只不過它們的用法不太相同,下面用一個例子來詳細說明下它們的異同之處:
import re str1 = 'Hello 111 is 222' str2 = str1.replace('111','222') print(str2)Hello 222 is 222 這是一個簡單的例子,如果是下面這種情形,把所有的數字都換成222,那么用replace實現起來就比較麻煩,而用re模塊的sub方法實現起來就比較的簡單:(如果是更復雜的操作,使用replace可能就無法實現了。)
import re str1 = 'Hello 123 is 456' str2 = re.sub('/d+','222',str1) print(str2)Hello 222 is 222 2、re.search()和re.match():
match: 只從字符串的開始與html' target='_blank'>正則表達式匹配,匹配成功返回matchobject,否則返回none.
search:將字符串的所有字串嘗試與正則表達式匹配,如果所有的字串都沒有匹配成功則返回none,否則返回matchobject.
下面這個例子說明了match和search的異同點,也說明了,在實際的應用中,search用的還是比較多的:
import restr = 'helloword,i am alex'if not re.match('word',str):print('cannot match')print(re.match('hello',str1).group())print(re.search('word',str1).group())#顯示結果cannot matchhelloword 3、re.split:
在Python中,如果想對一個字符串進行分割的話,只需要調用str的split方法就可以實現,但是這個split只能根據某個字符來進行分割的操作,如果要同時指定多個字符來進行分割的話,它就無法實現了。
好在re模塊也提供了split這個方法來對字符串進行分割,而且這個方法更加強大,可以同時根據多個字符進行分割的操作,下面來看分別看一下str的split和re的split有什么不同的地方:
str1 = 'helloword,i;am/nalex'str2 = str1.split(',')print(str2)import restr3 = re.split('[,|;|/n]',str1)print(str3)#下面是不同的輸出結果['helloword', 'i;am/nalex']['helloword', 'i', 'am', 'alex'] 從中我們可以看出,上面說的真實性。
4、findall:
findall方法基本上都是和compile方法同時出現的,它們的用法是:
先由compile將一個正則表達式的字符串形式轉換成pattern實例,然后再使用patte實例調用findall方法生成match對象來獲取結果,在將它們結合的實例之前,我們先來看下正則表達式中預設的特殊字符含義:
/d 匹配任何十進制數;它相當于類 [0-9]。 /D 匹配任何非數字字符;它相當于類 [^0-9]。 /s 匹配任何空白字符;它相當于類 [ "t"n"r"f"v]。 /S 匹配任何非空白字符;它相當于類 [^ "t"n"r"f"v]。 /w 匹配任何字母數字字符;它相當于類 [a-zA-Z0-9_]。 /W 匹配任何非字母數字字符;它相當于類 [^a-zA-Z0-9_]。
看完這幾個特殊字符的含義,我們再舉一個例子來說明一下上面的論點:
import restr1 = 'asdf12dvdve4gb4'pattern1 = re.compile('/d')pattern2 = re.compile('[0-9]')mch1 = pattern1.findall(str1)mch2 = pattern2.findall(str1)print('mch1:/t%s'% mch1)print('mch2:/t%s'% mch2)#輸出結果mch1: ['1', '2', '4', '4']13 mch2: ['1', '2', '4', '4'] 上面的兩個實例都可以很好的闡述上面的論點,而且也表明了,特殊字符/d確實跟[0-9]是一樣的,通過輸出結果就可以看出,那么如果你不想把每個數字都拆分為一個元素放在列表中,而是想把12整體的輸出出來,那么你可以這樣做:(就是在/d的后面加上個+號來實現的,這里的+號表示的是把一個或者多個相連的十進制數字整體輸出)
import restr1 = 'asdf12dvdve4gb4'pattern1 = re.compile('/d+')pattern2 = re.compile('[0-9]')mch1 = pattern1.findall(str1)mch2 = pattern2.findall(str1)print('mch1:/t%s'% mch1)print('mch2:/t%s'% mch2)#輸出結果mch1: ['12', '4', '4']mch2: ['1', '2', '4', '4'] 我們再舉一個小例子,這個例子是結合特殊字符和re的sub功能實現一下把字符串中所有的空格都給去掉:
import restr1 = 'asd /tf12d vdve4gb4'new_str = re.sub('/s*','',str)print(new_str)#輸出結果asdf12dvdve4gb4 5、元字符:
我們通常所說的二元字符有;2元字符:. ^ $ * + { } [ ] | ( ) /
我們首先考察的元字符是"[" 和 "]"。它們常用來指定一個字符類別,所謂字符類別就是你想匹配的一個字符集。字符可以單個列出,也可以用“-”號分隔的兩個給定
字符來表示一個字符區間。例如,[abc] 將匹配"a", "b", 或 "c"中的任意一個字符;也可以用區間[a-c]來表示同一字符集,和前者效果一致。如果你只想匹配小寫字母,那么 RE 應寫成 [a-z].元字符在類別里并不起作用。例如,[akm$]將匹配字符"a", "k", "m", 或 "$" 中的任意一個;"$"通常用作元字符,但在字符類別里,其特性被除去,恢復成普通字
符。
[]:元字符[]表示字符類,在一個字符類中,只有字符^、-、]和/有特殊含義。字符/仍然表示轉義,字符-可以定義字符范圍,字符^放在前面,表示非.(這個在上面的特殊字符示例中也有提現),
+ 匹配+號前內容1次至無限次
匹配 號前內容0次到1次
{m} 匹配前面的內容m次
{m,n} 匹配前面的內容m到n次
下面通過一個小例子,來闡述一下上面的字符在元字符[]中的使用:(在下面的這個例子中,要注意的有兩點:一是在/d+后面的?號的含義,二是在匹配的前面加上了一個字符r,其實在這個示例中,加與不加都可以顯示一樣的結果)
import re print(re.findall(r"a(/d+ )","a123b"))['1'] print(re.findall(r"a(/d+)","a123b"))['123'] 以上所述是小編給大家介紹的python 正則表達式學習小結,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對phpstudy網站的支持!PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久区二区 | 精品一区二区久久久 | 国产资源在线看 | 国产1区在线观看 | 99影视在线视频免费观看 | 欧美a∨一区二区三区久久黄 | 欧美性生活网站 | 亚洲成人福利在线观看 | 午夜视频成人 | 91网站在线播放 | 一本免费视频 | 欧美成人精品不卡视频在线观看 | 免费一级毛片网站 | 深夜福利视频免费观看 | 亚洲视频在线观看免费 | 美国人成人在线视频 | 成人性生活视频在线观看 | 国产精品久久久久久238 | 一级电影免费看 | 一级黄色性感片 | 中文字幕在线观看国产 | 欧美不卡 | 日本aaaa片毛片免费观看视频 | 成人国产精品色哟哟 | 亚州精品国产 | 久久精品国产一区二区 | 久久国产秒 | a级高清免费毛片av在线 | 午夜小网站 | 久久久久久久久久久国产精品 | 宅男噜噜噜66国产在线观看 | xxxxhd73国产| 午夜精品小视频 | wwwxxx视频 | 在线观看中文字幕av | 国产亚洲精品美女久久久 | 亚洲精品动漫在线观看 | 嫩草影院在线观看网站成人 | 国产毛片在线看 | 久久国产精品久久久久久久久久 | 亚洲精品成人18久久久久 |