正則表達式

本文主要講正則表達式的基本用法

python中導入模塊:import? re

【1】字符:^? ?.? ? *? ? $

^表示以什么字符開頭的字符串;

.表示任意字符

*代表前面的字符可以出現任意多次,包括0次

regex_str = "^b.*"? ?#^以‘b’開頭的任意字符串

regex_str1 = ".*3$" # $以3結尾任意字符串

regex_str2 = "^b.3$" #‘b’字符開頭,以3結尾,b和3之間可以是一個任意字符,只是匹配了三個字符的字符串

【2】字符:問號?? 非貪婪匹配,就是取消貪婪匹配(貪婪匹配與非貪婪匹配可以參考:正則表達式之 貪婪與非貪婪模式詳解

(1)

line2 = “aaaboooobbbb123”

regex_str3 = ".*?(b.*?b).*"? ?

match_object =?re.match(regex_str3,line2)

if match_object :

? ? print(match_object.group(1))? ?#輸出結果boooob ,regex_str3表達式括號里面的才是要輸出的值;

(2)

line=“study in 清華大學”

regex_str =".*?([\u4E00-\u9FA5])"+大學"? #這個[\u4E00-\u9FA5]是指匹配任意連續的中文字符,加號就是匹配在”大學“前面的一個或者多個的字符;

#如果不加?,就是貪婪模式,括號里面就這是會匹配到”華“,”清“字當成是前面的*匹配掉,后面就只能匹配一個字了,加?號后,取消貪婪匹配,后面就能匹配到”清華“

【3】字符:+加號,字符至少出現一次,限定前面的字符出現至少一次,*限定前面的字符出現0次到多次都行

line3= “aaaboooobaabbb123”

regex_str4=".*(b.+b).*"? #括號里面是要截取的內容,括號前面的可以是0位到多位的任意字符,從第一個b開始匹配,中間是一個字符至少有一位以上,然后又到右邊的一個b

match_object =?re.match(regex_str4,line3)

if match_object :

print(match_object.group(1))? ?#取得是括號里的內容,輸出結果baab ;

【4】字符:{},有三種模式? {2}和{2,}限定前面的字符自少出現多少次;{1,2}?限定前面的字符自少出現1次,最多等于2次

表達式:".*(b.{2}b).*"? ? 針對字符串“aaaboooobaabbb123”? 輸出?baab

【5】字符| 是或的意思

字符串:“boby123”

表達式“(body|body123)”? ?匹配body或者body123都行,要加括號才能打印出來,?print(match_object.group(1)) 打印出boby123

表達式“((body|boddy)123)” 匹配的是body123或者boddy123 ,.group(1)是指外面的括號,打印是完整的body123;;.group(2)是指里面的括號,打印是里面匹配的body

【6】中括號[ ],有三種用法:

? ? ? ? 【3,7,8】中括號里面的任意字符都行

? ? ? ? 【0-9】,【A-Za-z0-9_】表示區間,在這個區間的就行

? ? ? ? ?【^6】反義,不等于6就行

表達式:"(1[378][0-9]{9})" #字符串要求第一位是1,第二位是3/7/8,第三位到第9位是0到9區間出現9位({9}表示前面的那個區間的數據出現9次,剛剛好就是9位數字);注意小括號也一定要是英文的

【7】\s,\S,\w,\W?

? ? ? ?\s 表示一個空格字符串

? ? ? ?\S表示非空格的任意一個字符串

? ? ? \w表示【A-Za-z0-9_】這個里面的任意一個字符串

? ? ? \W表示不在【A-Za-z0-9_】這個區間內的任意一個字符串都行

【8】[\u4E00-\u9FA5]? 匹配連續的中文

表達式"[\u4E00-\u9FA5]+"? ?可以匹配到"中文s"這類的字符串,但是不能匹配到"中? 文"這樣字符串的后面一個‘文’字,只能是‘中’

【9】\d? 匹配連續的數字

line = "xxx出生2001年"

提取年份

reg_str = ".*?(\d+)年"

mo = re.match(reg_str,line)

if mo:

? ? print(mo.group(1))

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,837評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,196評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,688評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,654評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,456評論 6 406
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,955評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,044評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,195評論 0 287
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,725評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,608評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,802評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,318評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,048評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,422評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,673評論 1 281
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,424評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,762評論 2 372

推薦閱讀更多精彩內容