91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python的正則表達式如何實現

發布時間:2023-05-12 15:54:34 來源:億速云 閱讀:63 作者:iii 欄目:編程語言

本篇內容主要講解“Python的正則表達式如何實現”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Python的正則表達式如何實現”吧!

Python 正則表達式

正則表達式本身是獨立于編程語言的知識,但是它又依附于編程語言,基本上我們所使用的編程語言都提供了對它的實現,當然了,各家的實現也是有一些差異的,有的支持的功能多一點,有的支持的少一點。

因為正則表達式是實踐中使用廣泛的工具,所以脫離語言的學習我認為是不靠譜的。

正則表達式的函數介紹

正則表達式主要API關系圖

Python的正則表達式如何實現

這個圖是我個人總結的,我覺得基本上把這里的函數的關系弄清楚了,它們的作用是:

  • match 從文本的開頭匹配正則表達式,返回匹配的對象,沒有就返回 None

  • search 在整個文本中匹配正則表達式,返回第一個匹配的對象,沒有就返回 None。

  • sub 利用正則表達式進行文本替換(正則表達式的功能:搜索和替換)

  • findall 從整個文本中匹配正則表達式,以列表的形式返回所有匹配的結果。

  • finditer 從整個文本中匹配正則表達式,以迭代器的形式返回所有匹配的結果。

  • split 利用正則表達式切分文本

這里可以看出,·re· 下面有很多立即可以使用的函數,然后 re.compile 下面有很多同名的函數。直接在 ·re· 模塊下的是官方提供方便使用的函數,通過 re.compile 來使用是最正統的方式。所以,接下來的內容,我基本上智慧使用 re.compile 及其下的方法來實現。

re.compile 函數

compile 函數用于編譯正則表達式,生成一個正則表達式 (Pattern)對象,供 match()search() 以及其它函數使用。

語法:

re.compile(pattern[, flags])
  • pattern: 一個字符串形式的正則表達式

  • flags 可選,表示匹配模式,比如忽略大小寫,多行模式等,具體參數為:

    • re.I 忽略大小寫

    • re.L 多行模式

    • re.S 即為 '.' 并且包括換行符在內的任意字符('.' 不包括換行符)

    • re.U 表示特殊字符集 \w, \W, \b, \B, \d, \D, \s, \S 依賴 Unicode 字符屬性數據庫

    • re.X 為了增加可讀性,忽略空格和 ‘#’ 后面的注釋

示例:查找字符串中的所有數字

import re

s = 'runoob 123 google 456'
result1 = re.findall(r'\d+', s)

pattern = re.compile(r'\d+') # 查找數字
result2 = pattern.findall(s)
result3 = pattern.findall(s, 0, 20)


print(result1)
print(result2)
print(result3)


"""
output:
[‘123', ‘456']
[‘123', ‘456']
[‘123', ‘45']
"""
學習模板

接下來我們要逐漸學習正則表達的內容,這些內容是非常有趣的!Interesting and Excited!

這里給出一個接下來會一直使用的示例模板,這個模板是這篇博客最重要的東西了,之后的內容都會基于它進行擴展。所以,請好好理解它。

import re

# 需要進行搜索或者匹配的文本
text = """I love you yesterday and today."""

# 正則表達式
regexp = r'love'


# 編譯(對正則表達式進行編譯獲取 Pattern Object)
pattern = re.compile(regexp)

# 搜索
m = pattern.search(text)
if m:
    print("匹配對象: ", m)
    print("匹配的字符串: ", m.group())
    print("匹配的開始位置: ", m.start())
    print("匹配的結束位置: ", m.end())
    print("匹配位置的元組: ", m.span())
else:
    print("No match!")

# 替換
new_text = pattern.sub("hate", text)
print(new_text)

Python的正則表達式如何實現

注意: 正則表達式 regexp 在開始前會使用 r 前綴,這樣做的目的是為了避免在正則表達式中大量使用轉義字符,破壞了整體的可讀性。

Python 的正則表達式包含了很多非常易用的方法,但是這里我并不會過多介紹它們。我們會一直使用上面這種模式,因為那些易用的方法只是對它的一種封裝,學習使用這種基本的方式自然就會其它的了。

匹配對象 可以獲取有關正則表達式的信息,它最重要的方法和屬性是:

方法/屬性目的
group()返回正則匹配的字符串
start()返回匹配的開始位置
end()返回匹配的結束位置
span()返回包含匹配 (start, end) 位置的元組

到此,相信大家對“Python的正則表達式如何實現”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

游戏| 砚山县| 和平区| 积石山| 利津县| 四会市| 饶平县| 兴城市| 晋城| 镇平县| 迁西县| 内江市| 奉新县| 多伦县| 陇川县| 崇仁县| 龙门县| 霸州市| 顺昌县| 边坝县| 沙雅县| 永济市| 清河县| 宣城市| 白山市| 上高县| 桓台县| 依兰县| 运城市| 普兰县| 广水市| 五寨县| 普定县| 常熟市| 大化| 白玉县| 嘉祥县| 青龙| 灌阳县| 浑源县| 中山市|