国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

python語言之正則re使用方法

冬至配餃子 ? 來源:繆斯之子 ? 作者:肖新苗 ? 2022-08-23 10:35 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

. \w \s \d a|b () [...] {} * +

1. 常用元字符

. 匹配除換行符以外的任意字符

\w 匹配字母或數字或下劃線

\s 匹配任意的空白符

\d 匹配數字

\n 匹配一個換行符

\t 匹配一個制表符

^ 匹配字符串的開始

$ 匹配字符串的結尾

\W 匹配非字母或數字或下劃線

\D 匹配非數字

\S 匹配非空白符

a|b 匹配字符a或字符b

() 匹配括號內的表達式,也表示一個組

[...] 匹配字符組中的字符

[^...] 匹配除了字符組中字符的所有字符


2. 量詞:控制前面的元字符出現的次數


* 重復零次或更多次

+ 重復一次或更多次

? 重復零次或一次

{n} 重復n次

{n,} 重復n次或更多次


3. 貪婪匹配和惰性匹配


.* 貪婪匹配

.*? 非貪婪匹配


'''

點: 匹配所有不包括換行

+: 表示重復一次或者更多次,就是說如果條件一直符合的話,就連續匹配

import re

def test_dot():
data1 = 'hello \n world'
pattern = re.compile(r'.+')
res_list = pattern.findall(data1)
assert ['hello ', ' world'] == res_list, 're dot error'

2.點: 匹配所有包括換行

import re
def test_dot2():
# 有時候需要 . 能匹配所有字符,包括換行符, 就需要帶上參數 re.S
data1 = ''

# (.+) 括號說明: 正常會取整個,加括號之后,就只取括號里面的了
ptn = re.compile(r'', re.S)
res_list = ptn.findall(data1)
assert ['hello \n world'] == res_list, 're dot 2 error'

3. \w: 匹配數字、字母 和 下劃線

import re
def test_w():
data1 = 'ab_@.121'
# + 表示重復一次或者更多次,就是說如果條件一直符合的話,就連續輸出,比如:ab_
ptn = re.compile(r'\w+')
res_list = ptn.findall(data1)
assert ['ab_', '121'] == res_list, 're w error'

4.\s: 匹配任意的空白字符

import re
def test_s():
data1 = 'a b\tc\n d$#'
ptn = re.compile(r'\s+')
res_list = ptn.findall(data1)
assert [' ', '\t', '\n '] == res_list, 're s error'

5.\d: 匹配數字

import re
def test_d():
data1 = 'yidong 10086,liantong 10010'
ptn = re.compile(r'\d+')
res_list = ptn.findall(data1)
assert ['10086', '10010'] == res_list, 're d error'

6.^: 有兩個地方用到: 1.本例中的匹配字符串的開始, 2. 在中括號中,取非

import re
def test_start():
data1 = 'ab1ab2'
ptn = re.compile(r'ab\d')
res_list = ptn.findall(data1)
assert ['ab1', 'ab2'] == res_list, 're ^ error'

# ^ 表示只匹配字符串的開始
data1 = 'ab1ab2'
ptn = re.compile(r'^ab\d')
res_list = ptn.findall(data1)
assert ['ab1'] == res_list, 're ^ 2 error'

7.$: 匹配字符串的結束

import re
def test_end():
data1 = '1ab2ab'
ptn = re.compile(r'\dab$')
res_list = ptn.findall(data1)
assert ['2ab'] == res_list, 're $ error'

8. |: a|b 匹配字符串a或字符串b

import re
def test_and():
data1 = '12a_3$dc'
ptn = re.compile(r'\d+|a|d|c')
res_list = ptn.findall(data1)
assert ['12', 'a', '3', 'd', 'c'] == res_list, 're | error'

9. (): 表示一個組

import re
def test_bracket():
data1 = ''
ptn = re.compile(r'')
res_list = ptn.findall(data1)
assert ('1', 'xiaoxinmiao') == res_list[0], 're () error'

10. (): 可以通過?P定義組名

import re
def test_bracket2():
# 可以設置分組名
data1 = ''
ptn = re.compile(r'')
iter_obj = ptn.finditer(data1)
res_obj = iter_obj.__next__()
assert '1' == res_obj.group(
'id') and 'xiaoxinmiao' == res_obj.group('name'), 're () error'

11.(): 當有多組時的例子, 當然這種情況,直接用例子9更方便

import re
def test_bracket3():
# 可以設置分組名
data1 = ''
ptn = re.compile(
r'')
iter_obj = ptn.finditer(data1)
ids, names = [], []
for i in iter_obj:
ids.append(i.group('id'))
names.append(i.group('name'))
assert ['1', '2'] == ids and ['miao1', 'miao2'] == names, 're () error'

12.[]: 匹配字符串中的字符, 其中 - 表示區間,例如:1-9表示1,2,3,4,5,6,7,8,9

import re
def test_bracket_mid():
data1 = '12dss#$$fwe564_'
ptn = re.compile(r'[1-9a-z_$]+')
res_list = ptn.findall(data1)
assert ['12dss', '$$fwe564_'] == res_list, 're [] error'

13.[^]: 匹配除了字符串中的值

import re
def test_bracket_mid2():
data1 = '12dss#$$fwe564_'
# [^] 表示不匹配里面的任何數
ptn = re.compile(r'[^1-9a-z_$]+')
res_list = ptn.findall(data1)
assert ['#'] == res_list, 're [] error'

14. +, * , ? 的理解,但是并不常用, 最常用的還是這個組合 .*?


def test_liangci():
data1 = 'abccd'
# +: 前一個字符出現1次或者多次
re_list = re.findall(r'abc+', data1)
assert ['abcc'] == re_list, 're + error'

# *: 前一個字符出現0次或者多次
re_list = re.findall(r'abf*', data1)
assert ['ab'] == re_list, 're + error'

# ?: 前一個字符出現0次或者1次
re_list = re.findall(r'abc?', data1)
assert ['abc'] == re_list, 're + error'

16. .*?: 非貪婪模式, 直接看例子

import re
def test_star2():
# .* 貪婪
data1 = '我愛北京天安門,天安門上太陽升.'
res_list = re.findall(r'我愛(.*)天安門', data1)
assert ['北京天安門,'] == res_list, 're .* error'
# .*? 非貪婪
res_list = re.findall(r'我愛(.*?)天安門', data1)
assert ['北京'] == res_list, 're .* error'

17. {}: {n}重復多次,{n,}重復多次或者更多次

import re
def test_bracket_big():
# 只有兩位數字才符合要求
data1 = 'a1b12c134d1234e'
res_list = re.findall(r'\d{2}', data1)
assert ['12', '13', '12', '34'] == res_list, r're {} error'
# 兩位,以及兩位以上的數字都符合要求
data1 = 'a1b12c134d1234e'
res_list = re.findall(r'\d{2,}', data1)
assert ['12', '134', '1234'] == res_list, r're {} error'

18. []: 實戰,匹配中文

import re
def test_zh():
data1 ='我愛111北京%天安


審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 字符串
    +關注

    關注

    1

    文章

    596

    瀏覽量

    23165
  • python
    +關注

    關注

    57

    文章

    4876

    瀏覽量

    90025
  • ASSERT
    +關注

    關注

    0

    文章

    17

    瀏覽量

    7660
  • Split
    +關注

    關注

    0

    文章

    6

    瀏覽量

    5779
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    RTL9301管理型交換機DHCP Server使用方法

    RTL9301管理型交換機DHCP Server使用方法
    的頭像 發表于 02-01 10:52 ?1293次閱讀
    RTL9301管理型交換機DHCP Server<b class='flag-5'>使用方法</b>

    芯源IR調制器都有哪些具體使用?使用方法是怎樣的?

    芯源IR調制器都有哪些具體使用?以及使用方法是怎樣的?
    發表于 12-02 06:33

    堆棧的定義,堆棧的使用方法

    和使用; 對于8086CPU,進出堆棧的只能是2字節的數據。 2 堆棧的使用方法 常用的堆棧相關指令包括PUSH POP PUSHF和POPF,語法如下: PUSH 源操作數;將指定操作數入棧保護 POP
    發表于 11-21 06:49

    一文了解Mojo編程語言

    資源受限環境,如物聯網設備或實時控制系統。 總的來說,Mojo 的獨特之處在于它填補了 Python 與底層語言之間的性能鴻溝,同時保持了開發者熟悉的語法和生態。隨著其工具鏈的完善,Mojo 有望成為 AI 和高性能計算領域的重要工具。
    發表于 11-07 05:59

    EMC之RE問題那些事兒

    通過插拔線束定位干擾路徑來自哪兒。兩種方式沒有絕對的好與不好,根據不同的產品的類型和失效頻點是窄帶還是寬帶,選擇不同的方法。二問題背景車載導航產品在做RE輻射實驗
    的頭像 發表于 09-02 11:42 ?5404次閱讀
    EMC之<b class='flag-5'>RE</b>問題那些事兒

    功率放大器賦能:基于正則模態展開的管道彎曲處導波散射研究

    的散射特性對于優化無損檢測技術和提高結構健康監測的準確性至關重要。基于正則模態展開(normalmodeexpansion)的方法是研究管道彎曲處導波散射的一種有效手段。該方法通過將導波在管道中的傳播分解為一系列
    的頭像 發表于 08-28 11:29 ?505次閱讀
    功率放大器賦能:基于<b class='flag-5'>正則</b>模態展開的管道彎曲處導波散射研究

    Re-Driver 和 Re-Timer 有什么區別?

    Re-Driver 和 Re-Timer 有什么區別?
    發表于 08-21 06:14

    C++ 與 Python:樹莓派上哪種語言更優?

    Python是樹莓派上的首選編程語言,我們的大部分教程都使用它。然而,C++在物聯網項目中同樣廣受歡迎且功能強大。那么,在樹莓派項目中選擇哪種語言更合適呢?Python因其簡潔性、豐富
    的頭像 發表于 07-24 15:32 ?944次閱讀
    C++ 與 <b class='flag-5'>Python</b>:樹莓派上哪種<b class='flag-5'>語言</b>更優?

    錫膏的儲存及使用方法詳解

    錫膏是一種常用的焊接輔助材料,廣泛應用于電子、電器、通訊、儀表等行業的焊接工藝中。正確的儲存和使用方法對于保證錫膏的品質和焊接效果至關重要。本文將就錫膏的儲存和使用方法進行詳細介紹,希望能對廣大焊接工作者有所幫助。
    的頭像 發表于 07-18 17:36 ?1393次閱讀
    錫膏的儲存及<b class='flag-5'>使用方法</b>詳解

    labview如何使用VISA串口資源查找的正則表達式提取串口的資源名稱?

    如圖,如何利用VISA資源查找的正則表達式從很多串口當中提取想要的目標串口(Quectel USB AT Port這個串口)?
    發表于 07-07 17:20

    跟老齊學Python:從入門到精通

    礎的學習者介紹一門時下比較流行、并且用途比較廣泛的編程語言,所以,本書讀起來不晦澀,并且在其中穿插了很多貌似與Python 編程無關,但與學習者未來程序員職業生涯有關的內容。 獲取完整文檔資料可下載附件哦!!!! 如果內容有幫助可以關注、點贊、評論支持一下哦~
    發表于 06-03 16:10

    LCR測試儀的使用方法與注意事項

    LCR測試儀的使用方法、操作注意事項及常見故障處理,幫助讀者高效、安全地掌握這一儀器的使用技巧。 ? 二、LCR測試儀的基本使用方法 1. 準備階段 (1)設備檢查:確保測試儀電源線、連接線完好,電源開關關閉。檢查測試夾具或探針
    的頭像 發表于 04-29 10:36 ?1.3w次閱讀
    LCR測試儀的<b class='flag-5'>使用方法</b>與注意事項

    西門子PLC-模擬量采集計算使用方法

    西門子PLC-模擬量采集計算使用方法,很實用
    發表于 04-09 15:29 ?1次下載

    零基礎入門:如何在樹莓派上編寫和運行Python程序?

    是一種非常有用的編程語言,其語法易于閱讀,允許程序員使用比匯編、C或Java等語言更少的代碼行。Python編程語言最初實際上是作為Linux的腳本
    的頭像 發表于 03-25 09:27 ?2026次閱讀
    零基礎入門:如何在樹莓派上編寫和運行<b class='flag-5'>Python</b>程序?

    PXI-8433/4的規范使用方法分享

    應用中,因兩線制接線配置不當導致通訊障。本文將以此問題為入點,系統講解PXI-8433/4的規范使用方法
    的頭像 發表于 03-14 10:38 ?1944次閱讀
    PXI-8433/4的規范<b class='flag-5'>使用方法</b>分享