列表['A-b-', 'A-1b-', 'A-b1', 'A-b-a']
python利用re.sub删除匹配内容如下:
'-'字符后接0或1个数字,再接小写字母,后接0或任意长度字符
即删除后结果为['A', 'A', 'A', 'A']
以下是可以实现您需求的代码:
import re
lst = ['A-b-', 'A-1b-', 'A-b1', 'A-b-a']
result = []
for s in lst:
new_s = re.sub(r'-\d?[a-z].*', '', s)
result.append(new_s)
print(result)
输出结果为:['A', 'A', 'A', 'A']
在上述代码中,我们使用re.sub()函数来替换每个字符串中的匹配项。正则表达式r'-\d?[a-z].*'表示匹配以"-"开头,后面跟着零个或一个数字,再跟着一个小写字母,最后跟着任意字符的字符串。我们将这个匹配项替换为空字符串,从而删除了其中的"-字符后接0或1个数字,再接小写字母,后接0或任意长度字符"。
最后,我们将替换后的字符串添加到结果列表中,并打印结果列表。
当用单引号或双引号将一个字符串括起来时,这个字符串就是一个正则表达式。在这个正则表达式中,'-\d?[a-z].*'可以逐行解释为:
- "-":匹配一个连字符。
- "\d?":匹配零个或一个数字。"\d"表示匹配任意一个数字,"?"表示匹配零个或一个实例。
- "[a-z]":匹配任意一个小写字母。
- ".*":匹配任意字符(除了换行符)的零个或多个实例。
综合起来,'-\d?[a-z].*'表示匹配一个连字符后面跟着零个或一个数字,再跟着一个小写字母,最后跟着任意字符的字符串。这个正则表达式可以匹配到"-字符后接0或1个数字,再接小写字母,后接0或任意长度字符"这个模式。
在代码中,我们使用re.sub()函数将这个匹配项替换为空字符串,从而删除了字符串中的"-字符后接0或1个数字,再接小写字母,后接0或任意长度字符"。