0.

1.参考

Python正则表达式指南

https://docs.python.org/2/library/re.html

https://docs.python.org/2/howto/regex.html

https://docs.python.org/3/library/re.html

string re 备注
  re.match(pattern, string, flags=0) at the start of the string
S.find(sub [,start [,end]]) -> int re.search(pattern, string, flags=0) Scan through string looking for a match
S.replace(old, new[, count]) -> string re.findall(pattern, string, flags=0) re.finditer

2.分组 m.group()

xx

In [560]: m.group?
Docstring:
group([group1, ...]) -> str or tuple.
Return subgroup(s) of the match by indices or names.
For 0 returns the entire match.
Type: builtin_function_or_method In [542]: m=re.search(r'(-{1,2}(gr))','pro---gram-files') In [543]: m.group() #自带
Out[543]: '--gr' In [544]: m.group(0) #自带,返回整个匹配到的字符串 For 0 returns the entire match. 注意 m.string 是被检索的完整原文。。。
Out[544]: '--gr' In [545]: m.group(1)
Out[545]: '--gr' In [546]: m.group(2)
Out[546]: 'gr' In [547]: m.group(3) #加的 ( 不满足则报错
---------------------------------------------------------------------------
IndexError Traceback (most recent call last)
<ipython-input-547-71a2c7935517> in <module>()
----> 1 m.group(3) IndexError: no such group In [548]: m.group(1,2) #选择多个分组,返回tuple
Out[548]: ('--gr', 'gr') In [549]: m.groups() #选择所有分组
Out[549]: ('--gr', 'gr')

m.groupdict 用于命名分组

In [557]: m.groupdict?
Docstring:
groupdict([default=None]) -> dict.
Return a dictionary containing all the named subgroups of the match,
keyed by the subgroup name. The default argument is used for groups
that did not participate in the match
Type: builtin_function_or_method In [558]: m=re.search(r'(-{1,2}(?P<GR>gr))','pro---gram-files') In [559]: m.groupdict()
Out[559]: {'GR': 'gr'}

3.提取 re.findall()

re.findall(pattern, string, flags=0)

In [97]: text = "He was carefully disguised but captured quickly by police."

In [98]: re.findall(r"\w+ly", text)  #相当于 m.group(0)
Out[98]: ['carefully', 'quickly'] In [99]: re.findall(r"(\w+)ly", text) #手动加单个括号限定内容,相当于返回 m.group(1)
Out[99]: ['careful', 'quick'] In [100]: re.findall(r"((\w+)(ly))", text) #多个括号,从左到右数 (,相当于返回 m.groups()
Out[100]: [('carefully', 'careful', 'ly'), ('quickly', 'quick', 'ly')]

In [102]: re.findall(r"((1\w+)(ly))", text)
  Out[102]: []

4.替换 re.sub()

re.sub(pattern, repl, string, count=0, flags=0)

repl 里面的 前向引用 Backreferences, such as \6, are replaced with the substring matched by group 6 in the pattern. 也可以通过 func 实现。

注意 mysql regexp 不支持 \1

https://stackoverflow.com/questions/4122393/negative-backreferences-in-mysql-regexp  提到 unless you can install/use LIB_MYSQLUDF_PREG.

https://stackoverflow.com/questions/7058209/reference-to-groups-in-a-mysql-regex

In [158]: def func(m):
...: return m.group('DEF')+' '+m.group(2) #别名
...: In [159]: re.sub(r'(?P<DEF>def)\s+([a-z]+)\s*\(\s*\):', func, 'def func(): def f():')
Out[159]: 'def func def f' In [160]: re.sub(r'(?P<DEF>def)\s+([a-z]+)\s*\(\s*\):', r'\1 \2', 'def func(): def f():') #不支持 \别名
Out[160]: 'def func def f'

5. Backreferences 前向引用在 pattern

5.1扑克牌找对子

In [204]: re.search(r'(.).*\1','ab123')

In [205]: re.search(r'(.).*\1','ab121')
Out[205]: <_sre.SRE_Match at 0x71ca120> In [206]: _.group()
Out[206]: ''

5.2连续多个相同

In [207]: re.search(r'.{3}','')  #错误
Out[207]: <_sre.SRE_Match at 0x71b94a8> In [208]: re.search(r'(.){3}','') #错误
Out[208]: <_sre.SRE_Match at 0x71ca198> In [209]: re.search(r'(.)\1\1','') #正确 In [210]: re.search(r'(.)\1\1','')
Out[210]: <_sre.SRE_Match at 0x71ca210> In [211]: re.search(r'(.)\1{2}','')
Out[211]: <_sre.SRE_Match at 0x71ca288> In [212]: _.group()
Out[212]: ''

python之re正则简单够用的更多相关文章

  1. Python正则简单实例分析

    Python正则简单实例分析 本文实例讲述了Python正则简单用法.分享给大家供大家参考,具体如下: 悄悄打入公司内部UED的一个Python爱好者小众群,前两天一位牛人发了条消息: 小的测试题:  ...

  2. python浅谈正则的常用方法

    python浅谈正则的常用方法覆盖范围70%以上 上一次很多朋友写文字屏蔽说到要用正则表达,其实不是我不想用(我正则用得不是很多,看过我之前爬虫的都知道,我直接用BeautifulSoup的网页标签去 ...

  3. python匹配ip正则

    python匹配ip正则 #!/usr/bin/env python # -*- coding:utf-8 -*- import re ip_str = "asdad1.1.1.1sdfwe ...

  4. python 多线程就这么简单(续)

    之前讲了多线程的一篇博客,感觉讲的意犹未尽,其实,多线程非常有意思.因为我们在使用电脑的过程中无时无刻都在多进程和多线程.我们可以接着之前的例子继续讲.请先看我的上一篇博客. python 多线程就这 ...

  5. python模块介绍- HTMLParser 简单的HTML和XHTML解析器

    python模块介绍- HTMLParser 简单的HTML和XHTML解析器 2013-09-11 磁针石 #承接软件自动化实施与培训等gtalk:ouyangchongwu#gmail.comqq ...

  6. 基于Python使用SVM识别简单的字符验证码的完整代码开源分享

    关键字:Python,SVM,字符验证码,机器学习,验证码识别 1   概述 基于Python使用SVM识别简单的验证字符串的完整代码开源分享. 因为目前有了更厉害的新技术来解决这类问题了,但是本文作 ...

  7. Python的变量及简单数据类型

    Python的变量及简单类型 1.  变量 在Python编程中,变量是用来存放值或对像的容器.变量的名称可以自定义,但需遵循一定的规范,否则可能会引发一些错误.Python的变量可以分为数字.字符和 ...

  8. Python与C的简单比较(Python3.0)

    Python可以说是目前最火的语言之一了,人工智能的兴起让Python一夜之间变得家喻户晓,Python号称目前最最简单易学的语言,现在有不少高校开始将Python作为大一新生的入门语言.本萌新也刚开 ...

  9. Python 基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现

    基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现   by:授客 QQ:1033553122 测试环境 功能需求 实现思路 代码实践(关键技术点实现) 代码模块组织 ...

随机推荐

  1. 电脑浅色显示器不显示怎么办,如何用PS去除logo底色

    本人买了新电脑后,虽然电脑显示器颜色也不错,就是刚买回来提示个true color没正确安装,我也没在意,因为感觉电脑显示方面还是不错的,后来定做安装程序用logo图的时候,有个浅色背景色,自己没看出 ...

  2. 尝试dapper和postgresql

    大多数地方和其他数据库(MySQL)没有什么不同.只有几点要注意: 1.PostgreSQL表名和字段是区分大小写的,大小写不对会说字段不存在 2.插入Json数据时,要在字符串后面加上::json ...

  3. python基础5 字典

    一.字典 字典是python的基础数据类型之一:字典可以存储大量的数据,关系型数据. 同样他也是python中唯一的映射类的数据类型. 数据类型的分类: 可变的(不可哈希)数据类型:list,dict ...

  4. C++/CLI泛型应用

    2019年01月16日, QQ群友不知道要折腾什么, 提出了以下问题: 样例代码中的是C#语言写的, 翻译成C++/CLI就不会了, 于是我试着谢了一下, 发现可以实现, 于是就贴出来与大家分享, 源 ...

  5. ueditor 插件集成到 xadmin 中的相关操作

    安装 点击这里下载源码包 在相关的虚拟环境下安装源码方式安装 切入解压后路径进行 python setup.py install 注册 安装成功按照普通app一般注册在 django 程序的app 中 ...

  6. [Nmap] Regular script

    out of date: TCP:nmap.exe -sC -sS -sV -p 1-65535 -A -v -v -oX filename.xml ip UDP:nmap.exe -sC -sU - ...

  7. jmeter5.1测试dubbo接口

    dubbo接口功能介绍 客户端输入uncleyong(当然,也可以是其他字符串),服务端返回hello uncleyong 开发dubbo服务jmeter客户端 idea中创建模块dubbo_jmet ...

  8. maven 使用 log4j

    Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件,甚至是套接口服务器.NT的事件记录器.UNIX Syslog守护进程等:我们也可 ...

  9. JS学习笔记Day14

    一.正则表达式 (一)正则的概念 1.正则表达式是一种特殊的字符串模式,用于匹配一组字符串,就好比用模具做产品,而正则就是这个模具,定义一种规则去匹配符合规则的字符 (二)创建正则的方式 1.字面量的 ...

  10. Vue基础之es6

    什么是ECMAScript,以及es6的诞生? 1997年 ECMAScript 1.0 诞生 1999年12月 ECMAScript 3.0诞生,它 是一个巨大的成功,在业界得到了广泛的支持,它奠定 ...