gpt4 book ai didi

python - 如何精确匹配模式?

转载 作者:行者123 更新时间:2023-11-28 21:39:37 25 4
gpt4 key购买 nike

我有一个这样的文件列表:aaa.txt bbb.doc ccc.gjf ddd.exe。我想要扩展名为 gjf 的文件。由于某些原因,此文件不能是文件列表中的第一个或最后一个文件。也就是说,文件前后必须有一个空格。但是,我尝试了很多正则表达式,都无法获取文件:

pattern = re.compile(r'\s+(.*?gjf) ')
print pattern.findall('aaa.txt bbb.doc ccc.gjf ddd.exe')
result: ['bbb.doc ccc.gjf']
pattern = re.compile(r' (.*?gjf) ')
print pattern.findall('aaa.txt bbb.doc ccc.gjf ddd.exe')
result: ['bbb.doc ccc.gjf']

我该怎么办?

最佳答案

我不认为正则表达式对于这个问题是完全必要的:

s = 'aaa.txt bbb.doc ccc.gjf ddd.exe'
final_data = [i for i in s.split()[1:-1] if i.endswith('.gjf')]

输出:

['ccc.gjf']

但是,如果你真的需要正则表达式,你可以试试这个:

import re
s = 'aaa.txt eee.gjf bbb.doc ccc.gjf ddd.exe'
final_data = re.findall("(?<!^)[a-zA-Z0-9]+\.gjf(?!$)", s)

输出:

['eee.gjf', 'ccc.gjf']

关于python - 如何精确匹配模式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46586914/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com