python re怎样2022_01_29_20_24_52_3_30.txt取最后一个数字30?

问题遇到的现象和发生背景

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