python 正则表达式解决包含且不包含某字符串的问题
python 正则表达式解决包含且不包含某字符串的问题
本测试使用python的re.compile与re.search作为方法测试包含error不包含abc的实例
python简单正则里只介绍到了不包含某字符的正则:[^1-9a-z],[^abc]也只能完成不匹配a、b、c三个字母的功能,但是这个并不能实现不匹配"abc“字符串的功能
这里要用到正则表达式中的断言知识:
(?=X ) |
零宽度正先行断言。仅当子表达式 X 在 此位置的右侧匹配时才继续匹配。例如,/w+(?=/d) 与后跟数字的单词匹配,而不与该数字匹配。此构造不会回溯。 |
(?!X) |
零宽度负先行断言。仅当子表达式 X 不在 此位置的右侧匹配时才继续匹配。例如,例如,/w+(?!/d) 与后不跟数字的单词匹配,而不与该数字匹配 。 |
(?<=X) |
零宽度正后发断言。仅当子表达式 X 在 此位置的左侧匹配时才继续匹配。例如,(?<=19)99 与跟在 19 后面的 99 的实例匹配。此构造不会回溯。 |
(?<!X) |
零宽度负后发断言。仅当子表达式 X 不在此位置的左侧匹配时才继续匹配。例如,(?<!19)99 与不跟在 19 后面的 99 的实例匹配 |
从断言的表达形式可以看出,它用的就是分组符号,只不过开头都加了一个问号,这个问号就是在说这是一个非捕获组,这个组没有编号,不能用来后向引用,只能当做断言。(对于正则表达式的断言感兴趣的同学,可以再查一查资料,这里不多做赘述)
所以这里我们不想匹配abc字符串就得用这个表达式: (?!abc)
测试代码:
import re
p = re.compile(r'error(?!abc)'
print p.search("errorabc")
print p.search("errorab")
结果:
None
<_sre.SRE_Match object at 0x7f129ce34b90>
那么我想不匹配"error123bsc"这个字符串呢?你是不是以为 error.*(?!abc) 这么写这个正则就可以了,我们来试试
import re
p = re.compile(r'error.*(?!abc)'
print p.search("error123abc")
结果:
<_sre.SRE_Match object at 0x7f129ce34bf8>
看,失败了吧!那怎么写呢?这么写:error((?!abc).)*$
知道了(?!abc),那么可以理解((?!abc).)* 的意思就是匹配 不含abc的字符(?!abc) 跟 任意字符. 的组合,出现任何次*
很多人会问,"$"不是匹配行末尾么,确实是这个意思,不明白请精度上面一句话再来看正则,然后我们来测一下:
import re
p = re.compile(r'error((?!abc).)*$')
print p.search("error123abc")
print p.search("error123abc123")
print p.search("error123ab123")
结果:
None
None
<_sre.SRE_Match object at 0x7f129ce81a08>
明白了吧!
以此类推,你要是想匹配包含error不包含error前后的abc,那么应该是这么写这个正则:
测一下:
import re
p = re.compile(r'^((?!abc).)*error((?!abc).)*$')
print p.search("123abc123error123")
print p.search("123ab123error123")
结果:
None
<_sre.SRE_Match object at 0x7f129ce81a08>
我们要是想匹配包含error不包含多个字符串,比如abc和def,这么写正则: error((?!(abc|def)).)*$
测试:
import re
p = re.compile(r'error((?!(abc|def)).)*$')
print p.search("error123abc234")
print p.search("error123ab234")
print p.search("error123def234")
结果:
None
<_sre.SRE_Match object at 0x7f87973eccf0>
None
测试完成!
python 正则表达式解决包含且不包含某字符串的问题相关推荐
- 转载Python正则表达式匹配反斜杠'\'问题(——字符串转义与正则转义)
个人总结(非转载部分): 1.原始字串(字符串前加r,如r'xxx')常用在正则表达式中,在正则表达运算中,要进行正则转义(原始字串不原始) 实例: 2.普通字串若要用于正则表达式中,会先进行&quo ...
- python 正则表达式 re findall 返回能匹配的字符串
python 正则表达式 re findall 方法能够以列表的形式返回能匹配的子串. re.findall(pattern, string[, flags]): 搜索string,以列表形式返回全部 ...
- python正则表达式过滤非中英文和数字的字符串
import resentence = "厉害了我的村!40亩地种了这些"植苗",当年结果,村民富裕了"# 方法一re.sub('[^\w\u4e00-\u9f ...
- Python正则表达式如何进行字符串替换实例
Python正则表达式如何进行字符串替换实例 Python正则表达式在使用中会经常应用到字符串替换的代码.有很多人都不知道如何解决这个问题,下面的代码就告诉你其实这个问题无比的简单,希望你有所收获. ...
- Python正则表达式如何进行字符串替换
先来段网上的知识:http://developer.51cto.com/art/201003/188824.htm Python正则表达式在使用中会经常应用到字符串替换的代码.有很多人都不知道如何解决 ...
- Python正则表达式工具类文件的封装实例,提供了多个实例,并且在代码中包含中文注释
Python正则表达式工具类文件的封装实例,提供了多个实例,并且在代码中包含中文注释 import reclass RegexUtils:'''正则表达式工具类'''def __init__(self ...
- python正则表达式匹配包含或者不包含字符串的方法
记录下正则匹配包含或者不包含字符串的表达式 import time import refindStr = 'setAttr ".uvst[0].uvsn" -type " ...
- python文件名按数字排序_用Python按照文件的名字中包含的数字排序出文件
使用Python按照文件的名字中包含的数字排序出文件 原来的样式: file_list = ['第10周成绩.xlsx', '第11周成绩.xlsx', '第12周成绩.xlsx', '第13周成绩. ...
- python使用fpdf创建pdf文件包含:页眉、页脚并嵌入logo图片、设置使用中文字体
python使用fpdf创建pdf文件包含:页眉.页脚并嵌入logo图片.设置使用中文字体 #python使用fpdf创建页眉.页脚并嵌入logo图片.设置使用中文字体 from fpdf impor ...
最新文章
- 【量化投资】策略五(聚宽)
- nexus搭建和迁移
- 人民日报智慧媒体研究院与第四范式合资成立智媒新创 赋能智慧媒体创新
- windows服务器网站日志,windows服务器网站日志文件
- 基于windows平台的命令行软件安装工具Chocolatey的安装
- ubuntu 安装java jdk_「ubuntu安装jdk」Ubuntu安装jdk8的两种方式 - seo实验室
- MySql数据库连接种类
- 解决centos下缺少sasl.h的问题(#include <sasl/sasl.h>)
- 知方可补不足~UPDLOCK更新锁的使用
- 在缺乏贷后数据的情况下做好策略的调整把控
- 一款无需写任何代码即可一键生成前后端代码的开源工具
- 处理PHP字符串的10个简单方法
- 基于粒子群算法的IEEE-30节点系统MATLAB配网无功优化仿真,有各变量参数,及仿真程序
- 快播之父卷土重来 发布升级版快播,首个区块链视频Bliface
- qt视频教程qt入门教程嵌入式linux应用开发qt编程开发,QT项目实战教程-Qt应用项目实例开发视频教程...
- python文件或文本加密(4种方法)
- 初探三维计算机视觉(三维重建) —— 相机模型 + 双目系统 + 点云模型
- 如何修改植物大战僵尸文档
- 安装图解:Linux Mint 4.0(Daryna)(或者说完美的桌面系统)
- Salesforce(0):使用VsCode使用Aura组件并展示组件扩展