欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python如何用正則表達式提取字符串

 更新時間:2023年03月02日 14:37:50   作者:豬笨是念來過倒  
這篇文章主要介紹了python如何用正則表達式提取字符串問題,具有很好的參考價值,希望對大家有所幫助。

用正則表達式提取字符串

在日常工作中經(jīng)常遇見在文本中提取特定位置字符串的需求。

python的正則性能好,很適合做這類字符串的提取,正則表達式的提取一般分兩種情況,一種是提取在文本中提取單個位置的字符串,另一種是提取連續(xù)多個位置的字符串。

日志分析會遇到這種情況。

1. 單個位置的字符串提取

這種情況我們可以使用(.+?)這個正則表達式來提取. 舉例,一個字符串"a123b",如果我們想提取ab之間的值123,可以使用findall配合正則表達式,這樣會返回一個包含所以符合情況的list,代碼如下:

import re
str = "a123b"
print(re.findall(r"a(.+?)b",str))
#輸出['123']

1.1貪婪和非貪婪匹配

如果我們有一個字符串”a123b456b”,如果我們想匹配a和最后一個b之間的所有值而非a和第一個出現(xiàn)的b之間的值,可以用?來控制正則貪婪和非貪婪匹配的情況. 代碼如下:

import re
str = "a123b456b"
?
print(re.findall(r"a(.+?)b", str))
#輸出['123']
#?控制只匹配0或1個,所以只會輸出和最近的b之間的匹配情況
?
print(re.findall(r"a(.+)b", str))
#輸出['123b456']
?
print(re.findall(r"a(.*)b", str))
#輸出['123b456']

1.2多行匹配

如果你要多行匹配,那么需要加上re.S和re.M標志. 加上re.S后, .將會匹配換行符,默認.不會匹配換行符. 代碼如下:

str = "a23b\na34b"
?
re.findall(r"a(\d+)b.+a(\d+)b", str)
#輸出[]
#因為不能處理str中間有\(zhòng)n換行的情況
?
re.findall(r"a(\d+)b.+a(\d+)b", str, re.S)
#s輸出[('23', '34')]

加上re.M后,^$標志將會匹配每一行,默認^和$只會匹配第一行.

代碼如下:

str = "a23b\na34b"
?
re.findall(r"^a(\d+)b", str)
#輸出['23']
?
re.findall(r"^a(\d+)b", str, re.M)
#輸出['23', '34']

2. 連續(xù)多個位置的字符串提取

這種情況我們可以使用(?P<name>…)這個正則表達式來提取.

舉例:

如果我們有一行webserver的access日志:'192.168.0.1 25/Oct/2012:14:46:34 "GET /api HTTP/1.1" 200 44 "http://abc.com/search" "Mozilla/5.0"',我們想提取這行日志里面所有的內(nèi)容,可以寫多個(?P<name>expr)來提取,其中name可以更改為你為該位置字符串命名的變量,expr改成提取位置的正則即可.

代碼如下:

import re
line ='192.168.0.1 25/Oct/2012:14:46:34 "GET /api HTTP/1.1" 200 44 "http://abc.com/search"?
"Mozilla/5.0"'
reg = re.compile('^(?P<remote_ip>[^ ]*) (?P<date>[^ ]*) "(?P<request>[^"]*)"?
(?P<status>[^ ]*) (?P<size>[^ ]*) "(?P<referrer>[^"]*)" "(?P<user_agent>[^"]*)"')
regMatch = reg.match(line)
linebits = regMatch.groupdict()
print(linebits)
for k, v in linebits.items() :
? ? print(k+": "+v)

輸出的結(jié)果為:

status: 200
referrer:  
request: GET /api HTTP/1.1
user_agent: Mozilla/5.0
date: 25/Oct/2012:14:46:34size: 44
remote_ip: 192.168.0.1

用正則表達式提取字符串中的整數(shù)

直接上代碼吧~

import re
re.findall("\d+","asd1234")

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python簡單生成8位隨機密碼的方法

    Python簡單生成8位隨機密碼的方法

    這篇文章主要介紹了Python簡單生成8位隨機密碼的方法,結(jié)合實例形式分析了2種簡單生成隨機密碼的方法,非常簡單實用,需要的朋友可以參考下
    2017-05-05
  • 使用python獲取CPU和內(nèi)存信息的思路與實現(xiàn)(linux系統(tǒng))

    使用python獲取CPU和內(nèi)存信息的思路與實現(xiàn)(linux系統(tǒng))

    這篇文章主要介紹了python獲取CPU和內(nèi)存信息的思路與實現(xiàn),有需要的朋友可以參考一下
    2014-01-01
  • PHP webshell檢查工具 python實現(xiàn)代碼

    PHP webshell檢查工具 python實現(xiàn)代碼

    Web安全應(yīng)急響應(yīng)中,不免要檢查下服務(wù)器上是否被上傳了webshell,手工檢查比較慢,就寫了個腳本來檢查了。Windows平臺下已經(jīng)有了lake2寫的雷克圖的了,一般的檢查也夠用了,寫了個Linux下面的,用python寫的。
    2009-09-09
  • Python高級排序sort()函數(shù)使用技巧實例探索

    Python高級排序sort()函數(shù)使用技巧實例探索

    本文詳細介紹sort()函數(shù)的使用,包括基本排序、自定義排序、逆序排序等多種情況,并提供大量示例代碼,以幫助你充分理解和掌握這一函數(shù)的用法,探索更多sort()排序函數(shù)的作用
    2024-01-01
  • Python如何將一個EXCEL表拆分多個excel表

    Python如何將一個EXCEL表拆分多個excel表

    在Python中,你可以使用pandas庫來讀取Excel文件,并將一個大的Excel表格(工作表)拆分成多個單獨的Excel文件,這篇文章主要介紹了Python如何將一個EXCEL表拆分多個excel表,需要的朋友可以參考下
    2024-06-06
  • Python數(shù)據(jù)結(jié)構(gòu)鏈表操作從基礎(chǔ)到高級實例深究

    Python數(shù)據(jù)結(jié)構(gòu)鏈表操作從基礎(chǔ)到高級實例深究

    鏈表是一種基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu),它由一系列節(jié)點組成,每個節(jié)點都包含數(shù)據(jù)和指向下一個節(jié)點的引用,在Python中,可以使用類來實現(xiàn)鏈表,本文將介紹如何實現(xiàn)鏈表,并提供一些豐富的示例代碼來幫助你更好地理解其原理和應(yīng)用
    2023-12-12
  • Python如何安裝第三方模塊

    Python如何安裝第三方模塊

    在本篇文章里,小編給大家分享的是關(guān)于Python安裝第三方模塊的方法及實例代碼,需要的朋友們可以學(xué)習(xí)下。
    2020-05-05
  • Python模塊結(jié)構(gòu)與布局操作方法實例分析

    Python模塊結(jié)構(gòu)與布局操作方法實例分析

    這篇文章主要介紹了Python模塊結(jié)構(gòu)與布局操作方法,結(jié)合實例形式分析了Python模塊與布局的相關(guān)概念、使用方法與相關(guān)注意事項,需要的朋友可以參考下
    2017-07-07
  • 詳解python字符串駐留技術(shù)

    詳解python字符串駐留技術(shù)

    在本文中,我們將深入研究 Python 的內(nèi)部實現(xiàn),并了解 Python 如何使用一種名為字符串駐留(String Interning)的技術(shù),實現(xiàn)解釋器的高性能。
    2021-05-05
  • Python常用類型轉(zhuǎn)換實現(xiàn)代碼實例

    Python常用類型轉(zhuǎn)換實現(xiàn)代碼實例

    這篇文章主要介紹了Python常用類型轉(zhuǎn)換實現(xiàn)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07

最新評論