2018-07-09正则表达式

跳转到底部

由于新接的项目中要用到大量的正则表达式,所以对正则表达式进行了简单的复习

基础知识回顾:正则表达式是什么

正则表达式也称为匹配[模式]: list ,它由一组具有特定含义的字符串组成,通常用于匹配和替换文本。

回顾re模块:

import re # 导入re模块
dir(re) # 查看re模块的方法和属性
['A', 'ASCII', 'DEBUG', 'DOTALL', 'I', 'IGNORECASE', 'L', 'LOCALE', 'M', 'MULTILINE', 'RegexFlag', '
S', 'Scanner', 'T', 'TEMPLATE', 'U', 'UNICODE', 'VERBOSE', 'X', '_MAXCACHE','all', '_builtins
_', 'cached', 'doc', 'file', 'loader', 'name', 'package', 'spec', 'ver
sion
', '_alphanum_bytes', '_alphanum_str', '_cache', '_compile', '_compile_repl', '_expand', '_loc
ale', '_pattern_type', '_pickle', '_subx', 'compile', 'copyreg', 'enum', 'error', 'escape', 'findall
', 'finditer', 'fullmatch', 'functools', 'match', 'purge', 'search', 'split', 'sre_compile', 'sre_pa
rse', 'sub', 'subn', 'template']

加粗斜体是我们常用几个方法的 (只加粗没有斜体的是因为markdown的书写把魔法方法前边和后边的两个__认成加粗符号了,求大神指点)

match方法:re.match(str_request, str_text )

str_request:匹配条件
str_text:待匹配文本
match方法是匹配以str_request开头的str_text文本中的内容
返回的是一个匹配对象(Match Object)
需要调用group()方法去查看内容

>>> res = re.match("任彦彪","任彦彪真帅111111")
>>> res
<_sre.SRE_Match object; span=(0, 3), match='任彦彪'>
>>> res.group()
'任彦彪'

'任彦彪'
'''

findall方法:re.findall(str_request, str_text)

str_request:匹配条件
str_text:待匹配文本
与match方法的参数相同,但作用不同,findall方法是查询文本中所有符合条件的字符串,并返回一个列表

>>> res = re.findall(r"\d+","1 当前浏览量是8808次,回帖人数是200人")
>>> res
['1', '8808', '200']

既然用到了/d+我们就把元字符给复习一下吧

元字符:单个字符的匹配

代码 说明
. 匹配除换行符(\n)以外的任意字符
\w 匹配大小写字母或数字或下划线或汉字0-9、a-z、A-Z、_(下划线)、汉字和其他国家的语言符号
\W 匹配非字母或数字或下划线或汉字,跟\w正好相反
\s 匹配任意的空白符
\S 匹配任意非空白符
\d 匹配数字
\D 匹配非数字
\b 匹配单词的开始或结束
^ 匹配字符串的开始
$ 匹配字符串的结束
[] 匹配[]中列举的字符

字符转义

\是字符转义,比如你想匹配.或者*,直接打在条件里是不行的,所以需要用/来转义,/.的意思就是.没有匹配所有的意思了,只是一个. 程序演示如下:

>>> res = re.findall(".","sdsa卡卡..卡卡")
>>> res
['s', 'd', 's', 'a', '卡', '卡', '.', '.', '卡', '卡']
>>> res = re.findall("\.","sdsa卡卡..卡卡")
>>> res
['.', '.']

\同理,就表示一个\,比如想匹配路径,路径都是中间都是\有两个解决方案,方案一:一个\表示一个\,
我们需要两个\,那就是\\
方案二:在匹配条件前边加r r"\"此时\没有转义功能,就单纯表示\(我们都推荐这种!)

>>> res = re.match(r"C:\\","C:\\data\\a.txt")
>>> res
<_sre.SRE_Match object; span=(0, 3), match='C:\\'>
>> res = re.match("C:\\\\","C:\\data\\a.txt")
>>> res
<_sre.SRE_Match object; span=(0, 3), match='C:\\'>
>>> res = re.match("C:\\","C:\\data\\a.txt")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\re.py", line 172, in match
    return _compile(pattern, flags).match(string)
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\re.py", line 301, in _compile
    p = sre_compile.compile(pattern, flags)
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\sre_compile.py", line 562, in compile
    p = sre_parse.parse(p, flags)
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\sre_parse.py", line 855, in parse
    p = _parse_sub(source, pattern, flags & SRE_FLAG_VERBOSE, 0)
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\sre_parse.py", line 416, in _parse_sub
    not nested and not items))
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\sre_parse.py", line 488, in _parse
    sourceget()
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\sre_parse.py", line 255, in get
    self.__next()
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python36\lib\sre_parse.py", line 245, in __next
    self.string, len(self.string) - 1) from None
sre_constants.error: bad escape (end of pattern) at position 2

通过代码演示可以看到,方案一和方案二都能行得通, 我知道最后一句匹配不了,可是最后一个语句为什么会报错我很难受QAQ

匹配重复的内容:

<i id="list">a</i>

代码/用法 说明
* 重复零次或多次
+ 重复一次或多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n次到m次

<div id="jump">跳转到的地方</div>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容

  • python的re模块--细说正则表达式 可能是东半球最详细最全面的re教程,翻译自官方文档,因为官方文档写的是真...
    立而人阅读 22,833评论 4 46
  • Python中的正则表达式(re) import rere.match #从开始位置开始匹配,如果开头没有则无re...
    BigJeffWang阅读 7,050评论 0 99
  • python:正则表达式 什么是正则表达式 正则表达式也叫做匹配模式(Pattern),它由一组具有特定含义的字符...
    清清子衿木子水心阅读 466评论 0 2
  • #首先,python中的正则表达式大致分为以下几部分: 元字符 模式 函数 re 内置对象用法 分组用法 环视用法...
    mapuboy阅读 1,597评论 0 51
  • 寂寞冬寒夜敛声, 谁知月下小窗明。 迷心乱弄千丝绪, 异日行装欲哪程。
    糊涂印象阅读 126评论 0 0