IT源码网

Python/Shell 正则表达式与运用

sanshao 2020年10月19日 程序员 533 0

正则表达式用的地方是很多的。比如字符串处理过程中。最近遇到记录一下。

1. 比如在shell中

1 #!/bin/bash 
2  
3 str="date:2017-11-28 os:centos blackbord:blog" 
4  
5 echo $str | grep centos --color 
6 echo $str | grep -oE centos --color 
7 #组的使用 
8 echo $str | sed -rne 's/.*(date:[0-9]{4}-[0-9]{2}-[0-9]{2}).*(blackbord:[a-z]+).*/group:\1 group:\2/p'

执行输出:

1 date:2017-11-28 os:centos blackbord:blog 
2 centos 
3 group:date:2017-11-28 group:blackbord:blog

2. Python中

 1 #coding=utf-8 
 2 import re 
 3  
 4 str1="line:20 date(2017-11-28) os:centos blackbord[blog] last" 
 5  
 6 matchobj = re.search("(date\(\d+-\d+-\d+\)).*(os:[a-z]+).*(blackbord\[[a-z]+\])", str1) 
 7 if matchobj: 
 8     num = len(matchobj.groups()) 
 9     print "match_len:" + str(num) 
10     print matchobj.groups() 
11  
12     date = matchobj.group(1)    #date(2017-11-28) 
13     date = date[5:len(date)-1] 
14     os = matchobj.group(2)  #os:centos 
15     os = os[3:] 
16     blackbord = matchobj.group(3)   #blackbord[blog] 
17     blackbord = blackbord[10:len(blackbord) -1 ] 
18     print("date:%s\nos:%s\nblackbord:%s" % (date, os, blackbord)) 
19 else: 
20     print "not match str1"

 输出:

1 match_len:3 
2 ('date(2017-11-28)', 'os:centos', 'blackbord[blog]') 
3 date:2017-11-28 
4 os:centos 
5 blackbord:blog

 

例子中的正则表达式多次使用到了捕获组,主要是方便查找与输出。() 每个括号是一个捕获组。

评论关闭
IT源码网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!