正则表达式的使用方法主要有4种: re.search(进行正则匹配), re.match(从头开始匹配)  re.findall(找出所有符合条件的字符列表)  re.split(根据条件进行切分)  re.sub(根据条件进行替换)

匹配规则里的符号

# . 可以被当作任意字符, re.M 忽略开头的换行符

res = re.match('^c.+\d', 'cheng123ronghua', flags=re.M)
print(res)

# ^ 匹配当前字符串的开头, ^c表示已c开头,a$以a为结尾

res = re.search('^c[a-z]+a$', 'cdasda')
print(res.group())

# $ 表示结尾

res = re.search('r[a-zA-Z]+a$', 'cheng321ronGHua123aronghua')
print(res.group())

# * 表示匹配0个或者多个

print(re.findall('ab*', 'alexabbtomab'))

# ['a', 'abb', 'ab']

# + 表示匹配一个或者多个

print(re.findall('x\d+a', 'alex123abc'))

# ['x123a']

# ? 匹配0个或者一个

print(re.findall('宋惠乔?', '宋惠 宋惠乔'))

# ['宋惠', '宋惠乔']

# {1,3} 匹配一个到三个之间

print(re.findall('[0-9]{1,3}', 'alex123alex1alex12'))

# ['123', '1', '12']

# | 进行或操作的匹配,匹配其中一个即可

print(re.search('abc|ABC', 'abcABCCD').group())

# abc

# 将需要匹配的字母进行统一的保存

string = re.search('(abc){2}(\|\|=){2}', '123abcabc||=||=')
print(string.group()) # abcabc||=||=

# \A 表示以什么开头, 相当于上面的^

print(re.search('\Aa.+b\Z', 'a123b').group())

# a123b

# \Z 表示以什么结尾,相当于上面的$

print(re.search('b.+d\Z', '11b23d').group())

# b23d

# \D 匹配非数字

print(re.search('\D+', '123$-a').group())

# $-a

# \w 匹配数字或者字母

print(re.search('\w+o\w+', 'the old tsoms').group())

# tsoms

# \W 匹配非数字或者字母

print(re.search('\W+', 'abc123%-%-%abc').group())

# %-%-%

# \s 匹配空包字符 \n\r\t

print(re.findall('\s+', 'sd \r\n sd'))

# [' \r\n ']

# (?P<>[]+) 进行分组构造字典

A = re.search('(?P<id>[0-9]+)(?P<name>[a-z]+)', '123alex')
print(A.groupdict()) # {'id': '123', 'name': 'alex'}

# re.split() 进行数据切分

print(re.split('[ ]+', '123  123 12'))

# ['123', '123', '12']

# re.sub 表示将数字进行替换|

print(re.sub('[0-9]+', '|', 'acv1dae2dasd3ads'))

# acv|dae|dasd|ads

# 进行反斜杠匹配 r'\\'

print(re.split(r'\\', r'abc\123'))

# ['abc', '123']

# re.I 忽略大小写

print(re.search('[a-z]+', 'abcA', re.I).group())

# abcA

# re.M 忽略开头的\n

print(re.search('^d123', '\nd123456', flags=re.M).group())

# d123

# re.S 匹配所有的字符串,包括换行符

print(re.findall(r'd.+s', 'd123\n\rs123', flags=re.S))

# ['d123\n\rs']

这里编写了一个简单的计算器

import re

s = '1-2*((60-30 +(9-2*5/3+7/3*99/4*2998+10*568/14)*(-40 / 5))-(-4*3)/(16-3*2))'
s = s.replace(' ', '')
print(eval(s))
def get_grap(string): x = re.compile('\([^()]+\)').search(string)
if x == None:
return string
else:
return x.group() def cal(x):
if '*' in x:
return float(x.split('*')[0]) * float(x.split('*')[1])
else:
return float(x.split('/')[0]) / float(x.split('/')[1]) def cal_sum(x):
if '+' in x :
return float(x.split('+')[0]) + float(x.split('+')[1])
elif '-' in x:
return float(x.split('-')[0]) - float(x.split('-')[1]) def cal_grap(x):
# 找出其中的乘和除
while True:
y = re.compile('\d+(\.\d+)?[*/]-?\d+(\.\d+)?').search(x)
if y == None:
break
y = y.group()
x = x.replace(y, str(cal(y)))
#找出其中的加减操作
while True:
if re.search('[+][-]', x) != None:
x = re.sub('[+][-]', '-', x)
elif re.search('[-][-]', x) != None:
x = re.sub('[-][-]', '+', x) y = re.compile('-?\d+(\.\d+)?[+\-]\d+(\.\d+)?').search(x)
if y == None:
break
y = y.group()
x = x.replace(y, str(cal_sum(y))) return x while True:
if re.compile('\d+(\.\d+)?').search(s) != None:
if re.compile('\d+(\.\d+)?').search(s).group() == s:
break x = get_grap(s)
if re.search('\(.+\)', x) != None:
all = cal_grap(x)[1:-1]
else:
all = cal_grap(x)
s = s.replace(x, all) print(s)

python正则表达式解析(re)的更多相关文章

  1. Python 正则表达式解析HTML

  2. 比较详细Python正则表达式操作指南(re使用)

    比较详细Python正则表达式操作指南(re使用) Python 自1.5版本起增加了re 模块,它提供 Perl 风格的正则表达式模式.Python 1.5之前版本则是通过 regex 模块提供 E ...

  3. Python正则表达式学习摘要及资料

    摘要 在正则表达式中,如果直接给出字符,就是精确匹配. {m,n}? 对于前一个字符重复 m 到 n 次,并且取尽可能少的情况 在字符串'aaaaaa'中,a{2,4} 会匹配 4 个 a,但 a{2 ...

  4. python高效解析日志入库

    python脚本解析日志文件入库一般有三个重要的步骤:读文件.解析文件.入库.在这三个方面下功夫,可确保我们获得最优的性能(这里不讨论并发) 1 读文件:一次读一行,磁盘IO太多,效率低下:一次性读如 ...

  5. Python网页解析

    续上篇文章,网页抓取到手之后就是解析网页了. 在Python中解析网页的库不少,我最开始使用的是BeautifulSoup,貌似这个也是Python中最知名的HTML解析库.它主要的特点就是容错性很好 ...

  6. Python天天美味(15) - Python正则表达式操作指南(re使用)(转)

    http://www.cnblogs.com/coderzh/archive/2008/05/06/1185755.html 简介 Python 自1.5版本起增加了re 模块,它提供 Perl 风格 ...

  7. 【repost】Python正则表达式

    星光海豚   python正则表达式详解 正则表达式是一个很强大的字符串处理工具,几乎任何关于字符串的操作都可以使用正则表达式来完成,作为一个爬虫工作者,每天和字符串打交道,正则表达式更是不可或缺的技 ...

  8. python 正则表达式中反斜杠(\)的麻烦和陷阱

    这里是一点小心得:由于下面两个原因,在正则表达式中使用反斜杠就会产生了一个双重转换的问题. (1).python自身处理字符串时,反斜杠是用于转义字符 (2).正则表达式也使用反斜杠来转义字符     ...

  9. python正则表达式一[转]

    原文:http://blog.jobbole.com/74844/ 作为一个概念而言,正则表达式对于Python来说并不是独有的.但是,Python中的正则表达式在实际使用过程中还是有一些细小的差别. ...

随机推荐

  1. JavaWeb【Servlet】

    概念 Servlet是在服务器上运行的小程序.一个Servlet请求对应一个Java类(对应一个Wrapper容器),可以通过请求-响应模式访问这个驻留在内存中的小程序. Tomcat容器等级 上图表 ...

  2. docker使用上的错误

    docker启动问题 Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon ...

  3. linux基础—课堂随笔05_文本三剑客之SED

    1.简介 sed是非交互式的编辑器,它不会修改文件,除非使用shell重定向来保存结果.默认情况下,所有的输出行都被打印到屏幕上. sed编辑器逐行处理文件(或输入),并将结果发送到屏幕.具体过程如下 ...

  4. java 权限控制

    网上或参考书中,对于java权限控制大多给出一张看似很整齐很好记实则不好理解的表格,我整理了一个2.0升级版,自认为会好理解很多,希望可以有所帮助. 同一包内 不同包内 修饰符 当前类 非当前类(含子 ...

  5. Git 简要教程

    Git是一个管理系统,管理版本,管理内容(CMS),管理工作等. Git主要还是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. 工作流程是这样的: 克隆 Git 资源作为工作目录 ...

  6. C++第三次作业--作用域

    作用域 任何一种语言最基本的部分就是变量,而变量有两个非常重要的特性,作用域和生存期. 定义 作用域是变量的一个属性,某个变量在代码中有效的区域为该变量的作用域. 函数原型作用域 函数声明参数从参数声 ...

  7. 复杂sql优化步骤与技巧

    数据管理型系统,由于用户的要求或者系统设计要求,会出现大量表进行join,还要进行大量统计性数据查询展示,甚至数据权限控制等操作.最后会导致sql异常复杂,随着数据量增加,或者只是应用到生产环境(正式 ...

  8. 通过SSH解压缩.tar.gz、.gz、.zip文件的方法

    一般在linux下,常用的压缩格式有如下几个: .tar.gz..gz..zip 解压 .tar.gz 文件命令: tar -zxvf xxx.tar.gz 解压 .gz 文件命令: gunzip x ...

  9. 如何保存ActionMailbox inbound HTML email和关于ActionText与ActiveStorage的附加

    gi代码: https://github.com/gorails-screencasts/action-mailbox-action-text/commit/3aeedc09441696c9489ed ...

  10. 计算机基础之BIOS

    BIOS BIOS是英文"Basic Input Output System"的缩略词,直译过来后中文名称就是"基本输入输出系统".在IBM PC兼容系统上,是 ...