问题遇到的现象和发生背景
2022_01_29_20_24_52_3_30.txt
需要取最后一个_和.txt之间的数字
问题相关代码,请勿粘贴截图
运行结果及报错内容
我的解答思路和尝试过的方法
可以取最后一个_后面的30.txt然后切割,就是比较费劲,不知道有更方便的办法没有
2022_01_29_20_24_52_3_30.txt
需要取最后一个_和.txt之间的数字
可以取最后一个_后面的30.txt然后切割,就是比较费劲,不知道有更方便的办法没有
import re # 如果一定要re方法,我比较不熟练,但是分享一下我常用的思路
def pickup_end_number(filename): # 函数入口为你要检查的文件名
model = re.compile('\\d*.txt') # 使用compile定义好规律,比如结果实在文件结尾的,我们发现规律为:若干个连续数字,然后文件类型
check = model.findall(filename) # findall()返回结果列表
if len(check) != 0: # 如果列表不为空,就说明匹配到了
b = str(check[0]) # 我们取列表第一个,一般来说也是唯一一个元素
b = b.replace('.txt', '') # 去掉文件类型后缀
return b # 函数出口为b的str
# 假设这是你得到的文件名str列表
file_list = ['2022_01_29_20_24_52_3_3.txt', '2022_01_29_20_24_52_3_30.txt', '2022_01_29_20_24_52_3_300.txt']
for i in file_list:
c = pickup_end_number(i) # 写个循环,套用函数即可
print(c)
# 结果为:3、30、30