正则表达式中两个不同的匹配条件怎么在一条语句里执行
发布网友
发布时间:2022-04-19 04:30
我来回答
共3个回答
热心网友
时间:2022-04-19 06:00
1、打开sublime text3编辑器,新建一个py文件。import re,也就是引入regular expression正则表达式库。
2、test = re.compile(r'\*')print(test.findall("666*888"))如果要匹配星号,只需要在前面加上反斜杠。
3、如果不加上反斜杠就会出现错误。
4、test = re.compile(r'[*]')另一种方法就是用中括号把星号括起来,这样也可以查找到。
5、test = re.compile(r'6*')print(test.search("666*888"))实际上在正则表达式里面,星号代表这匹配0个或者多个,这里表示0个6,或者多个6。
热心网友
时间:2022-04-19 07:18
可以用|来分隔,比如在notepad++用正则表达式来查找包含ok的或者a出现了两次的内容
.*ok.*|a{2}
正则表达式1|正则表达式2|正则表达式3...
热心网友
时间:2022-04-19 08:52
可以用零宽断言来实现。
例如:
合并下列正则表达式:
A. 必须包含数字的正则表达式 .*\d
B. 必须包含英文的正则表达式 .*[a-zA-Z]
C. 字符串长度是8-12位的正则表达式 ^.{8,12}$
合并后结果:
(?=.*\d)(?=.*[a-zA-Z])^.{8,12}$
表示必须包含数字,必须包含字母,同时长度为8-12位的正则表达式
零宽断言语法:
零宽断言有四类,它不匹配字符,只匹配一个位置,这和\b很像。用于断言后面的内容。
(?=exp)也叫零宽度正预测先行断言,它断言自身出现的位置的后面能匹配表达式exp。比如\b\w+(?=ing\b),匹配以ing结尾的单词的前面部分(除了ing以外的部分),如查找I'm singing while you're dancing.时,它会匹配sing和danc。
(?<=exp)也叫零宽度正回顾后发断言,它断言自身出现的位置的前面能匹配表达式exp。比如(?<=\bre)\w+\b会匹配以re开头的单词的后半部分(除了re以外的部分),例如在查找reading a book时,它匹配ading。
零宽度负预测先行断言(?!exp),断言此位置的后面不能匹配表达式exp。例如:\d{3}(?!\d)匹配三位数字,而且这三位数字的后面不能是数字;\b((?!abc)\w)+\b匹配不包含连续字符串abc的单词。
同理,我们可以用(?<!exp),零宽度负回顾后发断言来断言此位置的前面不能匹配表达式exp:(?<![a-z])\d{7}匹配前面不是小写字母的七位数字。