Home  >  Article  >  Backend Development  >  Python cleverly uses regular expressions to obtain strings

Python cleverly uses regular expressions to obtain strings

高洛峰
高洛峰Original
2017-03-11 10:43:111614browse

I believe that you often encounter the need to extract strings at specific positions in text in your daily work. Python has very good regularity and is very suitable for extracting such strings, so this article will explain it to you in detail. The extraction techniques are explained through sample code, which is very helpful for everyone to understand. Friends in need can come and learn together.

Preface

I won’t go into the basic knowledge of regular expressions. Those who are interested can click here. There are generally two situations for extraction. One is to extract strings at a single position in the text, and the other is to extract strings at multiple consecutive positions. Log analysis will encounter this situation, and I will talk about the corresponding methods below.

1. String extraction at a single position

In this case we can use the regular expression (.+?) to extract. For example, for a string "a123b", if we want to extract the value 123 between ab, we can use findall with a regular expression, which will return a list containing all matching situations.

The code is as follows:

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

1.1 Greedy and non-greedy matching

If we have a String "a123b456b", if we want to match all values ​​between a and the last b instead of the value between a and the first occurrence of b, we can use ? to control the regular greedy and non-greedy matching.

The code is as follows:

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 Multi-line matching

If you want multi-line matching , then you need to add re.S and re.M flags. After adding re.S. Will match newline characters, default. Will not match newline characters.

The code is as follows:

str = "a23b\na34b"
re.findall(r"a(\d+)b.+a(\d+)b", str)
#输出[]
#因为不能处理str中间有\n换行的情况
re.findall(r"a(\d+)b.+a(\d+)b", str, re.S)
#s输出[('23', '34')]

After adding re.M, the ^$ mark will match each line. By default, ^ and $ will only Matches the first line.

The code is as follows:

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

##2. Extract strings at multiple consecutive positions

In this case we can use the regular expression

(?P8a11bc632ea32a57b3e3693c7987c420...) to extract. For example, if we have a line of webserver access log: '192.168.0.1 25/Oct/2012:14:46:34 "GET /api HTTP/1.1" 200 44 "http://abc.com/search" "Mozilla/5.0"', we want to extract all the contents in this log line, we can write multiple (?P8a11bc632ea32a57b3e3693c7987c420expr) to extract, where the name can be changed to what you want For variables named by position strings, expr can be changed to the regular expression for extracting the position.

The code is as follows:

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(&#39;^(?P<remote_ip>[^ ]*) (?P<date>[^ ]*) "(?P<request>[^"]*)" 
(?P<status>[^ ]*) (?P<size>[^ ]*) "(?P<referrer>[^"]*)" "(?P<user_agent>[^"]*)"&#39;)
regMatch = reg.match(line)
linebits = regMatch.groupdict()
print linebits
for k, v in linebits.items() :
 print k+": "+v

##The output result is:

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

Summary

The above is the detailed content of Python cleverly uses regular expressions to obtain strings. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn