python 正则基本方法
2017-04-11
学习python,免不了应对爬虫,初学爬虫最难理解的就是正则表达式。
比如我们要爬去网页上的某些内容,就像下面这种形式:
<p>safdsf</p><p>sdhjrth</p>
我们要提取标签内的内容,可以尝试来一次正则提取:
>>>s="<p>safdsf</p><p>sdhjrth</p>"
print(re.findall(r'<p>(.*)</p>',s)),这里我们使用findall方法,大家可以思考一下输出的结果,
['safdsf</a><a>sdhjrth']结果有点不尽人意,并没有将<p>标签完全去掉。这就要涉及到贪婪与非贪婪模式了,简单点来说就是一个?的问题
修改过后:
print(re.findall(r'<a>(.*?)</a>',s))
['safdsf', 'sdhjrth']
这样输出的结果就比较符合我们的要求了。所以正则表达式是非常值得研究的
下面介绍正则表达式的几个常用方法;
1,match()方法
大家不妨实验一下match()的方法,这里就简单说一下
>>>p=re.compile(r'[a-z]+')
首先我们先匹配一下,从字母a到z,
>>>print(p.match('345sdf5ggd6fg'))
输出:None
这里我们可以看到输出的结果是none,这是因为match()从字符串的第一位开始匹配,如果第一位不是字母,那么它就不会继续匹配下去。
>>>print(p.match('a345sdf5ggd6fg'))
<_sre.SRE_Match object; span=(0, 1), match='a'>
也就是说只要第一位不是字母,就无法匹配成功。大家可以看一下将p=re.compile(r'[a-z]+')后面的加号换成* 或者去掉。
p=re.compile(r'[a-z]+')
print(p.match('abcasd')) 结果:<_sre.SRE_Match object; span=(0, 6), match='abcasd'>
去掉之后
p=re.compile(r'[a-z]')
pritn(p.match('abcasd')) 结果: <_sre.SRE_Match object; span=(0, 1), match='a'>
这里的加号代表
匹配前面的子表达式一次或多次,关于正则表达的所有符号大家自己百度。
2..search()方法
关于search()方法,看上去就比 match更加完美了。
它没有match()只在第一位匹配的限制了。
>>>p=re.compile(r'[a-z]+')
>>>print(m=p.search('234abc'))
结果:<_sre.SRE_Match object; span=(3, 6), match='abc'>
的确是比match()方法好,主要看个人的实际应用。
3.finditer()方法
finditer() 则是将匹配对象作为一个迭代器返回,举个简单的例子吧。
p=re.compile(r'\d+')
for a in p.finditer('今天是4月11号'):
print(a.group(),a.span()) 4 (3, 4)
11 (5, 7)
4.findall()方法
与finditer不同的是,findall()方法返回的是一个列表,和search() match()一样。
5.返回的方法
group() 返回匹配的字符串
start() 返回匹配的开始位置
end() 返回匹配的结束位置
span() 返回一个元组表示匹配位置(开始,结束)
正则表达式的高级方法这里就不多说了,会在近期的文章中一一探讨。(大神勿喷)
python 正则基本方法的更多相关文章
- Python正则式的基本用法
Python正则式的基本用法 1.1基本规则 1.2重复 1.2.1最小匹配与精确匹配 1.3前向界定与后向界定 1.4组的基本知识 2.re模块的基本函数 2.1使用compile加速 2.2 ma ...
- Python正则匹配字母大小写不敏感在读xml中的应用
需要解决的问题:要匹配字符串,字符串中字母的大小写不确定,如何匹配? 问题出现之前是使用字符串比较的方式,比如要匹配'abc',则用语句: if s == 'abc':#s为需要匹配的字符串 prin ...
- python字符串的方法
python字符串的方法 ############7个基本方法############ 1:join def join(self, ab=None, pq=None, rs=None): # real ...
- Python正则替换字符串函数re.sub用法示例(1)
本文实例讲述了Python正则替换字符串函数re.sub用法.分享给大家供大家参考,具体如下: python re.sub属于python正则的标准库,主要是的功能是用正则匹配要替换的字符串然后把它替 ...
- python 正则进阶常用方法
表达式 描述 正则表达式示例 符号 literal 匹配文本字符串的字面值literal foo rel1|rel2 匹配正则表达式rel1或rel2 foo|bar . 匹配任何字符(除了\n之外) ...
- 认识python正则模块re
python正则模块re python中re中内置匹配.搜索.替换方法见博客---python附录-re.py模块源码(含re官方文档链接) 正则的应用是处理一些字符串,phthon的博文python ...
- python 正则相关函数全解析
前言:网上有很多关于python正则函数的方法说明,这里尽可能用最简单的demo把所有函数之间的逻辑关系说清楚,供参考. 1.最原始的 re.compile()这个函数一般是需要和其它函数一起使用的, ...
- Python测试函数的方法之一
Python测试函数的方法之一 首先介绍简单的try......except尝试运行的放例如下面的图和代码来简单介绍下: 注释:提醒以下代码环境为2.7.x 请3.x以上的同学们老规矩print(把打 ...
- 使用python原生的方法实现发送email
使用python原生的方法实现发送email import smtplib from email.mime.text import MIMEText from email.mime.multipart ...
随机推荐
- [development][endian] 字节序
首先字节序很不好理解, 其次,理解了又不好记住. 除了字节序, 还有位序. 那么到底怎么记住呢? 大端序,小端序还有另一个名字, 大尾序,小尾序. 这样就记住了, 我们以16进制打印一个数之后, 尾部 ...
- sparking water
1 2 It provides a way to initialize H2O services on each node in the Spark cluster and to access dat ...
- 打开对话框opendialog
//使用:OpenDialog控件. ldg.Options := ldg.Options + [ofAllowMultiSelect]; ldg.Filter := '作答文件ZF包.zf| ...
- word标题自动编号
1.打开word文档中多级列表->定义新的多级列表 2.根据下图设置级别对应的标题,然后确定
- Java之旅_面向对象_抽象类
参考并摘自:http://www.runoob.com/java/java-abstraction.html Java抽象类: 在面向对象的概念中,所有的对象都是通过类来描绘的,但是反过来,并不是所有 ...
- CloudStack和OpenStack该如何选择(如果准备选择OpenStack,请做好hack的准备。CloudStack的底层功能已经做的很完善了,更适合商用)
国内做云计算的目前基本会在OpenStack和CloudStack中做一个选择.CloudStack 和OpenStack选哪一个,要根据自己的业务模式和研发力量来定. 作者:来源:cloudstac ...
- LEO原创-FMX之你不知道的ARC
LEO原创13498714 FMX加入了ARC技术,对象创建后不用释放,FMX会帮你释放,是不是这样就不用关心对象的释放了呢,非也! 写简单的代码,这个功能也许很好用,但如果你写的是一个项目,那隐藏的 ...
- Kubernetes应用管理
除了容器资源管理和调度,Kubernetes另外一个核心价值是提供了针对不同类型应用管理的API接口集合,这些API集合把针对不同类型应用的管理能力分别到Kubernetes平台中.以Web业务(Lo ...
- GIt如何进行代码管理
一:Git账号设置(仅第一次需设置): 1.首先打开GIt Bash 界面
- es6 学习二 Generator
安装babel的拓展包(Polyfill) ,对Generator的转义 这是一个补完babel支持es6的拓展包,配置步骤为3个: 打开命令行键入 npm install --save-dev ba ...