python里使用正则表达式的DOTALL标志

原创 2017年10月30日 17:34:26
正常的情况下,正则表达式里的句号(.)是匹配任何除换行符之外的字符。但是有时你也想要求它连换行符也匹配,这时怎么办呢?其实不用急,可以使用DOTALL标志,就可以让它匹配所有字符,不再排除换行符了。如下例子:
#python 3.6
#蔡军生 
#http://blog.csdn.net/caimouse/article/details/51749579
#
import re

text = 'This is some text -- with punctuation.\nA second line.'
pattern = r'.+'
no_newlines = re.compile(pattern)
dotall = re.compile(pattern, re.DOTALL)

print('Text:\n  {!r}'.format(text))
print('Pattern:\n  {}'.format(pattern))
print('No newlines :')
for match in no_newlines.findall(text):
    print('  {!r}'.format(match))
print('Dotall      :')
for match in dotall.findall(text):
    print('  {!r}'.format(match))

结果输出如下:

Text:
  'This is some text -- with punctuation.\nA second line.'
Pattern:
  .+
No newlines :
  'This is some text -- with punctuation.'
  'A second line.'
Dotall      :
  'This is some text -- with punctuation.\nA second line.'

深入浅出Numpy
http://edu.csdn.net/course/detail/6149 

Python游戏开发入门

你也能动手修改C编译器

纸牌游戏开发

http://edu.csdn.net/course/detail/5538 

五子棋游戏开发

http://edu.csdn.net/course/detail/5487
RPG游戏从入门到精通
http://edu.csdn.net/course/detail/5246
WiX安装工具的使用
http://edu.csdn.net/course/detail/5207
俄罗斯方块游戏开发
http://edu.csdn.net/course/detail/5110
boost库入门基础
http://edu.csdn.net/course/detail/5029
Arduino入门基础
http://edu.csdn.net/course/detail/4931
Unity5.x游戏基础入门
http://edu.csdn.net/course/detail/4810
TensorFlow API攻略
http://edu.csdn.net/course/detail/4495
TensorFlow入门基本教程
http://edu.csdn.net/course/detail/4369
C++标准模板库从入门到精通 
http://edu.csdn.net/course/detail/3324
跟老菜鸟学C++
http://edu.csdn.net/course/detail/2901
跟老菜鸟学python
http://edu.csdn.net/course/detail/2592
在VC2015里学会使用tinyxml库
http://edu.csdn.net/course/detail/2590
在Windows下SVN的版本管理与实战 
http://edu.csdn.net/course/detail/2579
Visual Studio 2015开发C++程序的基本使用 
http://edu.csdn.net/course/detail/2570
在VC2015里使用protobuf协议
http://edu.csdn.net/course/detail/2582
在VC2015里学会使用MySQL数据库
http://edu.csdn.net/course/detail/2672



版权声明:本文为博主原创文章,未经博主允许不得转载。

正则表达式——编译标志

re.S .代表匹配任意单个字符,但是一般情况下\n \t字符却匹配不到。匹配时候加上re.S编译标志即可解决问题。 >>> import re >>> r1 = r"qq.com" #这里的‘....
  • u011402596
  • u011402596
  • 2015年10月25日 14:06
  • 679

python里使用正则表达式的MULTILINE标志

在前面学习的正则表达式里,有一些规则是对字符串的分行进行特别处理的,比如^和$的规则就是针对边界进行判定的,所以这些规则根据对换行符进行不同的处理,就会有不同的结果。当一串字符串中包含有换行符,如果设...
  • caimouse
  • caimouse
  • 2017年10月29日 11:11
  • 835

使用Python正则表达式RE从CSDN博客源代码中匹配出博客信息

#!coding:utf-8 import re import sys import urllib2 # 测试匹配中文信息 def TestReChinese( ): reload(sy...
  • gatieme
  • gatieme
  • 2015年01月29日 19:23
  • 17456

python里使用正则表达式的内嵌功能选项标志

在前面学习过正则表达式有一些标志,可以通过编译时添加进去。比如学习过的re.DOTALL标志,这些标志都是在编译设置的,如果不是立即编译正则表达式时,就不能使用这些参数。比如你需要把一个正则表达式当作...
  • caimouse
  • caimouse
  • 2017年11月05日 13:23
  • 3957

python里使用正则表达式

在前面学习了比较多模式,有前向搜索的,也有后向搜索的,有肯定模式的,也有否定模式的。这次再来学习一个,就是后向搜索肯定模式,意思就是说已经扫描过了的字符串,还想后悔去看一下,是否可以匹配。它的语法是:...
  • yangjiyue0520
  • yangjiyue0520
  • 2017年11月14日 09:52
  • 164

Python 使用正则表达式 - 1

正则表达式 python
  • hjh00
  • hjh00
  • 2015年08月19日 16:20
  • 1088

【python学习笔记】用正则表达式从含中文的网页中提取数据(含编码转换)

目标:用正则表达式从含中文的网页中提取数据 1、获得网页全部数据 1.1思考过程 确定我们要操作的网页:url = 'http://q.stock.sohu.com/cn/603077/cwzb.sh...
  • pzxzhy
  • pzxzhy
  • 2015年12月27日 17:05
  • 2549

python里使用正则表达式的重复模式

在前面学习的正则表达式,都是把每一个字符写出来的,但是如果有重复的字符,也需要写出来吗?比如重复1000个字符,这时全写出来就不是很聪明的做法了,那么怎么办呢?可以使用某种规则来生成。如下面的例子:#...
  • caimouse
  • caimouse
  • 2017年10月07日 14:14
  • 597

python正则表达式介绍及使用方法

元字符: 1.[ ]     常用来指定一个字符集:[abc]; [a-z]; [0-9]     元字符在字符集中不起作用:[akm$]     补集匹配不在区间范围内的字符:[^5] ; [^ab...
  • longshengguoji
  • longshengguoji
  • 2013年08月12日 18:34
  • 3291

python re 匹配回车 re.DOTALL

python re
  • jinyingqi22
  • jinyingqi22
  • 2016年04月08日 15:40
  • 1037
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:python里使用正则表达式的DOTALL标志
举报原因:
原因补充:

(最多只允许输入30个字)