[英]Python regex get substring after preceding substring match
文本沒有空格,因此我根本無法拆分,也無法在字符串列表上使用索引。
我正在尋找的模式是:
check=
它后跟數字和編碼的查詢字符串項(apache日志文件),並且在文件的每一行中兩次。 我想要的輸出可以讓我得到check=
例如,一行中的字符串如下所示:
11.249.222.103 - - [15/Aug/2016:13:17:56 -0600] "GET /next2/120005079807?check=37593467%2CCOB&check=37593378%2CUAP&box=match&submit=Next HTTP/1.1" 500 1633 "https://mvt.squaretwofinancial.com/newmed/?button=All&submit=Submit" "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0"
在這種情況下,我需要獲取37593467
和37593378
。
請檢查此代碼。
import re
text = '''11.249.222.103 - - [15/Aug/2016:13:17:56 -0600] "GET /next2/120005079807?check=37593467%2CCOB&check=37593378%2CUAP&box=match&submit=Next HTTP/1.1" 500 1633 "https://mvt.squaretwofinancial.com/newmed/?button=All&submit=Submit" "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0"'''
for match in re.findall("check=(\d+)",text):
print 'Found "%s"' % match
輸出:
C:\Users\dinesh_pundkar\Desktop>python demo.py
Found "37593467"
Found "37593378"
幾個URL尋求幫助:
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.