要求匹配为:
1.它一共有8位
2.它的前两位是大写英文
3.它的3、4位是小写英文
4.它的第5位和第8位是同一个字符
5.它的第6、7位是数字
正则表达式为:pattern = r'[A-Z]{2}[a-z]{2}(\S)\d{2}\1'
这就是那个正则表达式,慢慢来分析吧
r'..........' 这就是匹配的外部结构,跟内容没关系
[A-Z]{2} 前面中括号里的是匹配所有大写字母,后边的大括号意思是匹配的大写字母的个数
[a-z]{2} 同上
(\S) \S表示一个非空白字符,类似地 \s表示一个空白或者回车符,至于小括号,呵呵
\d{2} \d 任意单个数字, 大括号数字同上
\1 终于轮到小括号了,\1表示重复正则第一个圆括号内匹配到的内容 ,类推得 \2表示重复正则第二个圆括号内匹配到的内容....
也就是说,\1和之前的(\S),共同表示匹配的是两个相同的非空白字符
应该不晕吧,呵呵
用python就是这样的
pattern = r'[A-Z]{2}[a-z]{2}(\S)\d{2}\1'
result = re.search(pattern, s)
s是一个字符串,对了,之前要加上 这个 import re
还要注意的是,result匹配出来的并不直接是字符串,想要输出字符串,需要
print result.group(0)
完了,也还好吧