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

python利用正則表達(dá)式提取字符串

 更新時(shí)間:2016年12月08日 11:02:12   作者:風(fēng)引  
相信大家在日常工作中經(jīng)常會(huì)遇見(jiàn)在文本中提取特定位置字符串的需求,python的正則性很好,很適合做這類字符串的提取,所以這篇文章就給大家詳細(xì)講一下提取的技巧,并通過(guò)示例代碼講解,對(duì)大家理解很有幫助,有需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

前言

正則表達(dá)式的基礎(chǔ)知識(shí)就不說(shuō)了,有興趣的可以點(diǎn)擊這里,提取一般分兩種情況,一種是提取在文本中提取單個(gè)位置的字符串,另一種是提取連續(xù)多個(gè)位置的字符串。日志分析會(huì)遇到這種情況,下面我會(huì)分別講一下對(duì)應(yīng)的方法。

一、單個(gè)位置的字符串提取

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

代碼如下:

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

1.1貪婪和非貪婪匹配

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

代碼如下:

import re
str = "a123b456b"

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

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

print re.findall(r"a(.*)b", str)
#輸出['123b456']

1.2多行匹配

如果你要多行匹配,那么需要加上re.S和re.M標(biāo)志. 加上re.S后。將會(huì)匹配換行符,默認(rèn).不會(huì)匹配換行符。

代碼如下:

str = "a23b\na34b"

re.findall(r"a(\d+)b.+a(\d+)b", str)
#輸出[]
#因?yàn)椴荒芴幚韘tr中間有\(zhòng)n換行的情況

re.findall(r"a(\d+)b.+a(\d+)b", str, re.S)
#s輸出[('23', '34')]

加上re.M后,^$標(biāo)志將會(huì)匹配每一行,默認(rèn)^和$只會(huì)匹配第一行。

代碼如下:

str = "a23b\na34b"

re.findall(r"^a(\d+)b", str)
#輸出['23']

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

二、連續(xù)多個(gè)位置的字符串提取

這種情況我們可以使用(?P<name>…)這個(gè)正則表達(dá)式來(lái)提取。舉例,如果我們有一行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)容,可以寫(xiě)多個(gè)(?P<name>expr)來(lái)提取,其中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

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。

相關(guān)文章

  • Python學(xué)習(xí)筆記之函數(shù)的參數(shù)和返回值的使用

    Python學(xué)習(xí)筆記之函數(shù)的參數(shù)和返回值的使用

    這篇文章主要介紹了Python學(xué)習(xí)筆記之函數(shù)的參數(shù)和返回值的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • python爬取網(wǎng)易云音樂(lè)排行榜實(shí)例代碼

    python爬取網(wǎng)易云音樂(lè)排行榜實(shí)例代碼

    大家好,本篇文章主要講的是python爬取網(wǎng)易云音樂(lè)排行榜數(shù)據(jù)代碼,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Python去除字符串兩端空格的方法

    Python去除字符串兩端空格的方法

    這篇文章主要介紹了Python去除字符串兩端空格的方法,本文主要講解了string.lstrip、string.rstrip、string.strip等函數(shù)的運(yùn)用,需要的朋友可以參考下
    2015-05-05
  • python3通過(guò)subprocess模塊調(diào)用腳本并和腳本交互的操作

    python3通過(guò)subprocess模塊調(diào)用腳本并和腳本交互的操作

    這篇文章主要介紹了python3通過(guò)subprocess模塊調(diào)用腳本并和腳本交互的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • Python子類繼承父類構(gòu)造函數(shù)詳解

    Python子類繼承父類構(gòu)造函數(shù)詳解

    在本文里我們給大家分享一篇關(guān)于Python 子類繼承父類構(gòu)造函數(shù)的相關(guān)知識(shí)點(diǎn)內(nèi)容,需要的朋友們跟著學(xué)習(xí)下。
    2019-02-02
  • 教大家使用Python SqlAlchemy

    教大家使用Python SqlAlchemy

    如何使用Python SqlAlchemy,本文為大家詳細(xì)介紹Python SqlAlchemy的使用方法,感興趣的朋友可以參考一下
    2016-02-02
  • matplotlib一維散點(diǎn)分布圖的實(shí)現(xiàn)

    matplotlib一維散點(diǎn)分布圖的實(shí)現(xiàn)

    本文主要介紹了matplotlib一維散點(diǎn)分布圖的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • python加載自定義詞典實(shí)例

    python加載自定義詞典實(shí)例

    今天小編就為大家分享一篇python加載自定義詞典實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-12-12
  • pytorch實(shí)現(xiàn)MNIST手寫(xiě)體識(shí)別

    pytorch實(shí)現(xiàn)MNIST手寫(xiě)體識(shí)別

    這篇文章主要為大家詳細(xì)介紹了pytorch實(shí)現(xiàn)MNIST手寫(xiě)體識(shí)別,使用全連接神經(jīng)網(wǎng)絡(luò),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • pandas read_excel()和to_excel()函數(shù)解析

    pandas read_excel()和to_excel()函數(shù)解析

    這篇文章主要介紹了pandas read_excel()和to_excel()函數(shù)解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09

最新評(píng)論