python基础知识---正则
一、python正则简介
python的re模块,让python能够支持perl正则
perl正则的字符集("." "[abc]" "(abc)" "a|b")、锚点("$" "^" "\<\>")、修饰字符("*" "?" "+" "{}") 这里不做介绍
二、re模块中的函数,主要是三种匹配(match、search、findall)、一种替换(sub)、一种分割(split)
3种匹配之间比较:
1,match、search如果匹配到内容则返回一个对象(MatchObject对象),否则返回None,findall返回一个列表(包括空列表)
2,使用group()和groups()方法访问MatchObject对象
3,match只能匹配行首的pattern,search能够匹配非行首的pattern
3种匹配的第3个参数用法:
flags被指定为一个可选的标志。多个标志可以通过按位 OR(|) 来指定。如 re.I | re.M 被设置成 I 和 M 标志:
修饰符 | 描述 |
---|---|
re.I | 使匹配对大小写不敏感 |
re.L | 做本地化识别(locale-aware)匹配 |
re.M | 多行匹配,影响 ^ 和 $ |
re.S | 使 . 匹配包括换行在内的所有字符 |
re.U | 根据Unicode字符集解析字符。这个标志影响 \w, \W, \b, \B. |
re.X | 该标志通过给予你更灵活的格式以便你将正则表达式写得更易于理解。 |
1,match(apttern,string,flags=0)
flag:标志位,用来控制match的匹配方式,一般都没有指定,默认0
match用来从起始位置开始根据模型去字符串中匹配指定内容,如果没有匹配到内容,会返回None 如果匹配到内容 会返回一个MatchObject的对象
使用group()和groups()方法访问匹配的内容
import re string="1234erqwe123" obj=re.match('\d+',string) #返回一个对象 print(obj) print(obj.group()) #使用group()方法访问匹配的内容 #<_sre.SRE_Match object; span=(0, 4), match='1234'> #
import re string="@$1234erqwe123" obj1=re.match('([^0-9]+)(\d+)',string) print(obj1.group()) #group()返回一个字符串 print(obj1.groups()) #groups()返回一个元组 #@$1234 #('@$', '1234')
2,search(pattern, string, flags=0)
search和match就一处区别,可以匹配非行首的pattern,也是通过group()和groups()访问匹配到的数据
string="#$1234erqwe123" obj=re.search('(\d+)([^0-9]+)',string) print(obj.group()) print(obj.groups()) #1234erqwe #('1234', 'erqwe')
3,findall(pattern,string,flags=0)
match和search只能匹配一个pattern ,如果想匹配字符串中所有符合要求的pattern ,使用findall()
findall函数返回一个列表
import re string="#$1234erqwe123" obj=re.findall('\d+',string) #findall函数返回一个列表 print(obj) #['1234', '123']
4,sub(pattern,repl,string,n=0)
sub用于替换指定的字符串 ,比字符串方法replace功能丰富
import re string="1234erqwe123adfa123" new_string=re.sub('\d+','**',string) #返回替换后的副本,原字符串不变 new_string2=re.sub('\d+','**',string,2) #可指定替换前n个pattern,后面的不替换 print(string) print(new_string) print(new_string2) #1234erqwe123adfa123 #**erqwe**adfa** #**erqwe**adfa123
sub函数的第二个参数,可以是字符串,也可以是函数,这个链接有详细解释当sub函数的第二个参数是字符串时,可以使用 "\\1" r"\1" "\g<1>" "\g<name>" 反向引用当sub函数的第二个参数是函数时,pattern每匹配到一个实例,就会传一个MatchObject对象给函数,函数的返回值,就是要"替换成"的内容 5,split(pattern,string,n)split用于按指定匹配切割字符串,n表示按前n个pattern分割,如果n为空则表示按所有的pattern切割,返回一个列表split函数比字符串方法split功能丰富
import re string="1234erqwe123adfa123" new_string=re.split('\d+',string,1) #以前1个pattern为分割符 new_string1=re.split('\d+',string,2) #以前2个pattern为分割符 new_string2=re.split('(\d+)',string,1) #如果pattern中带有括号,括号里面的内容会返回 new_string3=re.split('(\d+)',string,2) # print(new_string) print(new_string1) print(new_string2) print(new_string3) #['', 'erqwe123adfa123'] #['', 'erqwe', 'adfa123'] #['', '1234', 'erqwe123adfa123'] #['', '1234', 'erqwe', '123', 'adfa123']
三、python应用示例---计算器#主要使用到正则函数、迭代、字符串格式化
import re def chengfa_chufa(string): if not re.findall('\*|/',string): return string expression_list=re.split('([+-]?[0-9.]+[*/][+-]?[0-9.]+)',string,1) number_list=re.split('([*/])',expression_list[1],1) left_number=float(number_list[0]) right_number=float(number_list[2]) if number_list[1]=='*': result=left_number*right_number else: result=left_number/right_number if result>0: # result='+'+str(result) result='%s%s' %('+',result) # string_new=expression_list[0]+str(result)+expression_list[2] string_new='%s%s%s' %(expression_list[0],result,expression_list[2]) if re.findall('\*|/',string_new): return chengfa_chufa(string_new) else: # print(string_new) return string_new #-2+3-4+6.7 def jiafa_jianfa(string): string=string.replace('+-','-').replace('-+','-').replace('++','+').replace('--','+') expression_list=re.split('([-+][0-9.]+)',string) result=0 for i in expression_list: if i : num=float(i) result=result+num return result def main(string): if not re.findall('\(|\)',string): return jiafa_jianfa(chengfa_chufa(string)) expression_list=re.split('\(([^)(]+)\)',string,1) result=jiafa_jianfa(chengfa_chufa(expression_list[1])) # string_new=expression_list[0]+str(result)+expression_list[2] string_new='%s%s%s' %(expression_list[0],result,expression_list[2]) if re.findall('\(|\)',string_new): return main(string_new) else: return jiafa_jianfa(chengfa_chufa(string_new)) if __name__=='__main__': string=input('input expression: ') result=main(string) print(result)
python基础知识---正则的更多相关文章
- Python开发【第二篇】:Python基础知识
Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...
- python基础知识(二)
以下内容,作为python基础知识的补充,主要涉及基础数据类型的创建及特性,以及新数据类型Bytes类型的引入介绍
- python 基础知识(一)
python 基础知识(一) 一.python发展介绍 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本 ...
- python基础知识讲解——@classmethod和@staticmethod的作用
python基础知识讲解——@classmethod和@staticmethod的作用 在类的成员函数中,可以添加@classmethod和@staticmethod修饰符,这两者有一定的差异,简单来 ...
- python爬虫主要就是五个模块:爬虫启动入口模块,URL管理器存放已经爬虫的URL和待爬虫URL列表,html下载器,html解析器,html输出器 同时可以掌握到urllib2的使用、bs4(BeautifulSoup)页面解析器、re正则表达式、urlparse、python基础知识回顾(set集合操作)等相关内容。
本次python爬虫百步百科,里面详细分析了爬虫的步骤,对每一步代码都有详细的注释说明,可通过本案例掌握python爬虫的特点: 1.爬虫调度入口(crawler_main.py) # coding: ...
- python 爬虫与数据可视化--python基础知识
摘要:偶然机会接触到python语音,感觉语法简单.功能强大,刚好朋友分享了一个网课<python 爬虫与数据可视化>,于是在工作与闲暇时间学习起来,并做如下课程笔记整理,整体大概分为4个 ...
- python基础知识小结-运维笔记
接触python已有一段时间了,下面针对python基础知识的使用做一完整梳理:1)避免‘\n’等特殊字符的两种方式: a)利用转义字符‘\’ b)利用原始字符‘r’ print r'c:\now' ...
- Python基础知识(五)
# -*- coding: utf-8 -*-# @Time : 2018-12-25 19:31# @Author : 三斤春药# @Email : zhou_wanchun@qq.com# @Fi ...
- Python基础知识(Basic knowledge)
Python基础知识(Basic knowledge) 1.认识Python&基础环境搭建 2.Python基础(上) 3.Python基础(中) 4.Python基础(下) 5.Python ...
随机推荐
- MySql 打开日志文件
-- 查看系统变量 show variables like '%general%'; set global general_log=on;
- Web API数据传输加密
http://www.cnblogs.com/wuhuacong/p/4620300.html Web API应用架构设计分析(2) 在上篇随笔<Web API应用架构设计分析(1)>, ...
- 【转】JSch - Java实现的SFTP(文件上传详解篇)
JSch是Java Secure Channel的缩写.JSch是一个SSH2的纯Java实现.它允许你连接到一个SSH服务器,并且可以使用端口转发,X11转发,文件传输等,当然你也可以集成它的功能到 ...
- cordova环境配置
1,安装node.js 2,安装git 3,安装cordova 安装node.js后,命令行输入:npm install -g cordova 加@版本号可安装指定版本,如:npm istall -g ...
- 黄聪:css3实现图片划过一束光闪过效果(图片光影掠过效果)
CSS代码 .guangshu { display:block; position: relative; width:800px; height:450px; margin:0 auto;} .gua ...
- Eclipse插件安装方式及使用说明
拷贝安装方式 1.通过ECLIPSE_HOME\plugins安装 在eclipse的主目录ECLIPSE_HOME, 比如在我的机器上安装的目录是:ECLIPSE_HOME有一个plugins的目录 ...
- Spring Mvc Rest为不支持DELETE/PUT的浏览器添加DELETE/PUT支持
现在都流行RESTFul,但是有一个问题,有些浏览器现在就不支持delete/put方式的请求,这些请求发出去之后都会变成get请求,导致rest接口无法被访问到.为了解决这个问题,spring提出了 ...
- 快速开发一个PHP电影爬虫
今天来做一个PHP电影小爬虫.我们来利用simple_html_dom的采集数据实例,这是一个PHP的库,上手很容易.simple_html_dom 可以很好的帮助我们利用php解析html文档.通过 ...
- sqlite升级--浅谈Android数据库版本升级及数据的迁移
Android开发涉及到的数据库采用的是轻量级的SQLite3,而在实际开发中,在存储一些简单的数据,使用SharedPreferences就足够了,只有在存储数据结构稍微复杂的时候,才会使用数据库来 ...
- selenium之 定位以及切换frame(iframe)
Set<String> windows = driver.getWindowHandles(); int count = 0; for(String handl ...