濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 正則表達(dá)式+Python re模塊詳解

正則表達(dá)式+Python re模塊詳解

熱門標(biāo)簽:400電話辦理電話辦理 西藏智能外呼系統(tǒng)代理商 呼叫系統(tǒng)外呼只能兩次 ai電話機(jī)器人搭建 甘肅醫(yī)療外呼系統(tǒng)排名 貴港公司如何申請(qǐng)400電話 地圖標(biāo)注教學(xué)點(diǎn) 外呼系統(tǒng)無(wú)呼出路由是什么原因 梅縣地圖標(biāo)注

 正則表達(dá)式(Regluar Expressions)又稱規(guī)則表達(dá)式,在代碼中常簡(jiǎn)寫為REs,regexes或regexp(regex patterns)。它本質(zhì)上是一個(gè)小巧的、高度專用的編程語(yǔ)言。 通過(guò)正則表達(dá)式可以對(duì)指定的文本實(shí)現(xiàn)
匹配測(cè)試、內(nèi)容查找、內(nèi)容替換、字符串分割 等功能。

re模塊介紹

Python中的re模塊提供了一個(gè)正則表達(dá)式引擎接口,它允許我們將正則表達(dá)式編譯成模式對(duì)象,然后通過(guò)這些模式對(duì)象執(zhí)行模式匹配搜索和字符串分割、子串替換等操作。re模塊為這些操作分別提供了模塊級(jí)別的函數(shù)以及相關(guān)類的封裝。

正則表達(dá)式一些小規(guī)則

    ①元字符

  ②量詞

③貪婪和非貪婪匹配

    總是在量詞范圍內(nèi)盡量多匹配 - 貪婪
    總是在量詞范圍內(nèi)盡量少匹配 - 惰性
    .*?x 匹配任意內(nèi)容任意次數(shù) 遇到x就停止
    .+?x 匹配任意內(nèi)容至少1次 遇到x就停止

    ④轉(zhuǎn)義符問(wèn)題

    . 有特殊的意義,取消特殊的意義\
    取消一個(gè)元字符的特殊意義有兩種方法
    在這個(gè)元字符前面加 \
     對(duì)一部分字符生效,把這個(gè)元字符放在字符組里
    [.()+?*]

Python --> re模塊

findall
        會(huì)優(yōu)先顯示分組內(nèi)的內(nèi)容
        *****取消優(yōu)先顯示(?:正則)
search
        只能返回第一個(gè)符合條件的項(xiàng)
        得到的結(jié)果需要.group取值
        默認(rèn)獲取完整的匹配結(jié)果
        通過(guò)group(n)取第n個(gè)分組中的內(nèi)容

# search 還是按照完整的正則進(jìn)行匹配,顯示也顯示匹配到的第一個(gè)內(nèi)容,但是我們可以通過(guò)給group方法傳參數(shù)
# 來(lái)獲取具體文組中的內(nèi)容
ret = re.search('9(\d)(\d)','19740ash93010uru')
print(ret) # 變量 -- > re.Match object; span=(1, 4), match='974'>
if ret:
  print(ret.group()) # --> 974
  print(ret.group(1)) # --> 7
  print(ret.group(2)) # --> 4

# findall
  # 取所有符合條件的,優(yōu)先顯示分組中的
# search 只取第一個(gè)符合條件的,沒(méi)有優(yōu)先顯示這件事兒
  # 得到的結(jié)果是一個(gè)變量
    # 變量.group() 的結(jié)果 完全和 變量.group(0)的結(jié)果一致
    # 變量.group(n) 的形式來(lái)指定獲取第n個(gè)分組中匹配到的內(nèi)容

# 加上括號(hào) 是為了對(duì)真正需要的內(nèi)容進(jìn)行提取
ret = re.findall('\w+>(\w+)/\w+>','h1>askh930s02391j192agsj/h1>')
print(ret) # --> ['askh930s02391j192agsj']

    其他的內(nèi)容在代碼中有詳細(xì)的注釋,大家可以復(fù)制我的代碼一步一步運(yùn)行然后實(shí)驗(yàn)

    以下的內(nèi)容有:split sub subn math,compile,finditer

# split sub subn math,compile,finditer
# split
res = re.split('\d+', "cyx123456cyxx")
print(res) # --> ['cyx', 'cyxx']
res = re.split('(\d+)', "cyx123456cyxx") # 保留分組
print(res) # --> ['cyx', '123456', 'cyxx']
# sub 替換
res = re.sub('\d+', '我把數(shù)字替換了',
       "cyx123456cyxxx123456") # 默認(rèn)全部替換,當(dāng)然也可以替換一次re.sub('\d+','我把數(shù)字替換了',"cyx123456cyxxx123456",1)
print(res) # --> cyx我把數(shù)字替換了cyxxx我把數(shù)字替換了
# subn 替換了并顯示替換的次數(shù)
res = re.subn('\d+', '我把數(shù)字替換了', "cyx123456cyxxx123456")
print(res) # --> ('cyx我把數(shù)字替換了cyxxx我把數(shù)字替換了', 2)
# match 這個(gè)就相當(dāng)與加了個(gè)^ (和search差不多) --> 主要用來(lái)規(guī)定這個(gè)字符號(hào)必須是什么樣的
res = re.match('\d+', 'cyx123456cyxxx')
print(res) # --> None
res = re.match('\d+', '123cyx456cyxxx')
print(res.group()) # --> 123
# compile -- 節(jié)省代碼的時(shí)間的工具
# 假如同一個(gè)正則表達(dá)式要被使用多次
# 節(jié)省了多次解析同一個(gè)正則表達(dá)式的時(shí)間
ret = re.compile("\d+")
res = ret.search("cyx12456cyxXX123")
print(res.group()) # --> 12456
# finditer --> 節(jié)省空間
ret = re.finditer("\d+", "cyx123456cyxxx125644")
for r in ret:
  print(r.group()) # --> 123456
  # 125644
# 怎么又節(jié)省時(shí)間又節(jié)省空間呢?
ret = re.compile('\d+')
res = ret.finditer("cyx222231fddsf45746sdf2123sdf56456sdf10123sdf123132sdf")
for r in res:
  print(r.group())
"""
222231
45746
2123
56456
10123
123132
"""
# 分組命名(?P組名>正則) (?P=組名)
# 有的時(shí)候我們要匹配的內(nèi)容是包含在不想要的內(nèi)容之中的,
# 只能先把不想要的內(nèi)容匹配出來(lái),然后再想辦法從結(jié)果中去掉
# 分組命名的用法 (找兩個(gè)組里面是一樣的內(nèi)容)
exp = 'abc>asdasf54545645698asdasd/abc>00545sdfsdf/abd>'
ret = re.search('(?Ptag>\w+)>.*?/(?P=tag)', exp)
print(ret) # -- > re.Match object; span=(0, 33), match='abc>asdasf54545645698asdasd/abc'>
# exp2:
import re
ret = re.search('\d(\d)\d(\w+?)(\d)(\w)\d(\d)\d(?Pname1>\w+?)(\d)(\w)\d(\d)\d(?Pname2>\w+?)(\d)(\w)',
        '123abc45678agsf_123abc45678agsf123abc45678agsf')
print(ret.group('name1')) # -- > agsf_123abc
print(ret.group('name2')) # -- > agsf

今日小思考

    當(dāng)我們有一個(gè)這樣的列表:

lis = ['', 'z', 'c', 'asd', 'sdf', '', 'asd']

    那么我們?nèi)绾螌⒗锩娴目兆址麆h除呢?

ret = filter(lambda n: n, lis)
print(list(ret)) # --> ['z', 'c', 'asd', 'sdf', 'asd']

總結(jié)

到此這篇關(guān)于正則表達(dá)式+Python re模塊詳解的文章就介紹到這了,更多相關(guān)正則表達(dá)式 python re模塊內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python之re模塊案例詳解
  • python re模塊匹配貪婪和非貪婪模式詳解
  • python的re模塊使用方法詳解
  • 詳解Python正則表達(dá)式re模塊
  • python re模塊的高級(jí)用法詳解
  • python正則表達(dá)式re模塊詳解
  • Python之re模塊詳解

標(biāo)簽:湖州 涼山 常州 泰安 哈密 大興安嶺 本溪

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《正則表達(dá)式+Python re模塊詳解》,本文關(guān)鍵詞  正則,表達(dá)式,+Python,模塊,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《正則表達(dá)式+Python re模塊詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于正則表達(dá)式+Python re模塊詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    林周县| 义马市| 赣榆县| 苍山县| 克什克腾旗| 华亭县| 大邑县| 永德县| 阿坝县| 遵化市| 铜陵市| 九江县| 石柱| 隆昌县| 石城县| 大安市| 定结县| 界首市| 乐山市| 安徽省| 达州市| 东乡族自治县| 田林县| 侯马市| 阳新县| 裕民县| 延寿县| 蓬溪县| 定结县| 西乡县| 理塘县| 嘉兴市| 青海省| 绥江县| 宜阳县| 三明市| 花莲市| 濮阳县| 青海省| 博客| 承德市|