本文主要是給大家介紹的是,Python中正則表達式如何實現重疊匹配的具體操作方法,給大家貼出了具體實例代碼,希望能給各位讀者帶來一定的幫助。
import regex string = '100101010001' str_re = '101' print(regex.findall(str_re, string, overlapped=True))
普通的re庫匹配,只能匹配一個’101’。
正則表達式可理解為對數據篩選的表達式,是有限個原子和元字符組成。
原子:基本組成單位,每個表達式至少有一個原子
普通字符組成原子 | |
---|---|
非打印字符組成原子 (不打印在輸出臺的字符) | \n:換行 \t:tab退格符 |
通用字符組成原子 | \w:匹配任意字母、數字、下劃線 \W:與\w相反 \d:匹配任意十進制數 \D:與\d相反 \s:匹配任意空白字符,如空格、換行、縮進 \S:與\s相反 |
原子表組成原子 | 一組原子組成一個表,由[]聲明 表內原子優先級相等,但內容只出現依次 若原子表以 ^ 開頭,則表示取反 |
#普通字符組成原子 pat1 = "abcd" #非打印字符組成原子 pat2 = "\n" #通用字符做原子 pat3 = "\w" #原子表組成原子 pat4 = "py[abc]" #可以匹配pya,pyb,pyc,但匹配pyab等原子表重復出現的情況失敗 #原子表開頭帶 ^ 表示取反 pat5 = "py[^abc]" #第三個位置匹配除了a,b,c外的任意一個字符
元字符:正則表達式中具有特殊含義的字符
. | 匹配任意字符,除了換行符 |
---|---|
^ | 匹配字符串開始的位置 |
$ | 匹配字符串結束的位置,當出現多組符合的匹配時,返回字符串最后的那組匹配 |
* | 匹配 0,1,n 次前面的原子【貪婪模式:盡可能多的匹配】 |
? | 匹配 0,1 次前面的原子【懶惰模式:精確匹配】 |
+ | 匹配 1,n 次前面的原子 |
{ j } | 前面的原子出現 j 次 |
{ j , } | 前面的原子至少出現 j 次 |
{ j , k } | 前面的原子至少出現 j 次,至多出現 k 次 |
i | j | 匹配 i 或 j ,若 i 與 j 同時出現,匹配 i |
( ) | 組,限制這組數據的組合如()內所描述一樣,只返回符合括號內描述的內容 |
模式修正符
即函數中 flag 位置的參數,在不改變正則表達式的情況下改變其含義,調整匹配結果。
re.I | 匹配時忽略大小寫 |
re.M | 多行匹配 |
re.L | 本地化識別匹配 |
re.U | 根據unicon字符匹配,影響\w \W |
re.S | 匹配包括換行符 |
正則表達式是對字符串進行模糊匹配,其中一個應用為正則匹配。正則匹配是python爬蟲的一個使用技術,用于在爬取的文本信息中提取目標信息。
正則匹配常用的函數:(調用正則表達式模塊re)
re.search(pat, str[, flag]):掃描字符串str,返回pat的位置(第一次成功匹配的),flag用于控制正則表達式的匹配方式
import re str = 'python' pat = 'pytho[a-n]' print(re.search(pat, str))
re.match(pat, str[, flag]):掃描字符串str開始的位置,返回pat的位置(第一次成功匹配的),flag用于控制正則表達式的匹配方式【若開始就不符合則結束,返回none】
import re str_1 = 'hello world' str_2 = 'world hello' pat = 'world' print(re.match(pat, str_1)) print(re.match(pat, str_2))
re.complie(pat[, flag]):
編譯正則表達式pat,返回正則表達式對象
findall(str[, pos[, endpos]]):
匹配所有,用列表返回string中所有匹配到的子串【不止第一次】,pos和endpos可指定在string中的起始位置
re.complie(pat).findall(str):全局匹配函數,匹配str中所有符合pat的子串,裝入一個列表返回結果
import re str = "hello world hello world hello world" pat = "hello" print(re.complie(pat).findall(str)) print(re.complie(pat).findall(str, 5, 15))
re.sub(pat, repl, str[, count[, flag]]):
替換字符串中的匹配項【清洗數據】,可用count指定最大替換次數
import re str = "400-823-823" pat = "-" #短橫改空格,最大替換次數2 str_new = re.sub(pat, " ", str, count=2)
以上就是給大家的一些總結,希望可以為各位讀者帶來幫助,請大家繼續關注讀者哦。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/127594.html
摘要:數據規整化清理轉換合并重塑數據聚合與分組運算數據規整化清理轉換合并重塑合并數據集可根據一個或多個鍵將不同中的行鏈接起來。函數根據樣本分位數對數據進行面元劃分。字典或,給出待分組軸上的值與分組名之間的對應關系。 本篇內容為整理《利用Python進行數據分析》,博主使用代碼為 Python3,部分內容和書本有出入。 在前幾篇中我們介紹了 NumPy、pandas、matplotlib 三個...
摘要:下面實現日期格式的解析,要把傳入的日期格式做匹配,然后從對象解析出對應的值,再拼到一塊。 最近在翻看原來寫的工具函數中,發現了formatDate這個工具函數,原來只是在使用,具體的實現原理沒有仔細研究過,這次就來分析一下它的實現,了解一下正則表達式的一個實戰應用。 函數功能 formatDate 函數接受兩個參數,日期對象和格式參數,可以根據不同的格式參數將事件對象轉換成日期格式,大...
摘要:正則表達式使用反斜杠來表示特殊形式,或者把特殊字符轉義成普通字符。解決辦法是對于正則表達式樣式使用的原始字符串表示法在帶有前綴的字符串字面值中,反斜杠不必做任何特殊處理。為了避免警告,需要將它們用反斜杠轉義。 上一篇文章:Python標準庫---18、文本處理服務:string 常見的字符串操作下一篇文章: 這個模塊提供了與 Perl 語言類似的正則表達式匹配操作。 模式和被搜索的字...
摘要:如果經過一系列輸入,最終如果能達到狀態,則輸入內容一定滿足正則表達式。正則表達式可以轉換為,已經有成熟的算法實現這一轉換。不過有時候轉換為可能導致狀態空間的指數增長,因此直接用識別正則表達式。 原文地址 先來看一個讓人震撼的小故事,故事來自知乎問題PC用戶的哪些行為讓你當時就震驚了? 同學在一個化妝品公司上班,旁邊一個大媽(四十多歲)發給他一個exl表,讓他在里面幫忙找一個經銷商的資料...
摘要:學習筆記七數學形態學關注的是圖像中的形狀,它提供了一些方法用于檢測形狀和改變形狀。學習筆記十一尺度不變特征變換,簡稱是圖像局部特征提取的現代方法基于區域圖像塊的分析。本文的目的是簡明扼要地說明的編碼機制,并給出一些建議。 showImg(https://segmentfault.com/img/bVRJbz?w=900&h=385); 前言 開始之前,我們先來看這樣一個提問: pyth...
閱讀 910·2023-01-14 11:38
閱讀 877·2023-01-14 11:04
閱讀 740·2023-01-14 10:48
閱讀 1980·2023-01-14 10:34
閱讀 941·2023-01-14 10:24
閱讀 818·2023-01-14 10:18
閱讀 498·2023-01-14 10:09
閱讀 571·2023-01-14 10:02