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
.*_(.*?).txt
str = re.findall("2022_01_29_20_24_52_3_30.txt",.*_(.*?).txt,re.S)[0]
a = '2022_01_29_20_24_52_3_30.txt' # 如果你的文件格式不变,其实可以不同re
a = a.strip('.txt') # 首先去点后缀
# print(a):2022_01_29_20_24_52_3_30
a = a.split('_') # 以‘_’为分隔符,生成列表
# print(a):['2022', '01', '29', '20', '24', '52', '3', '30']
a = str(a[-1]) # 取列表最后一个元素即可(如果你想要字符串为str(), 整数int())
# print(a):30