png = '''10day.png
20day.png
20day-1.png
30day.png
40day.png
40day-1.png
40day-2.png'''.split('\n')
dic = {}
for p in png:
....prefix = p.split('day')[0]
....suffix = int(p.split('day')[-1].replace('.png', '').replace('-', '') or 0)
....dic[prefix] = max(dic.get(prefix, 0), suffix)
print(dic)
# {'10': 0, '20': 1, '30': 0, '40': 2}
res = [f'{k}day'+(f'-{v}' if v else '') + '.png' for k, v in dic.items()]
print(res)
# ['10day.png', '20day-1.png', '30day.png', '40day-2.png']
我会这样做 给你参考
※ 引述《tzouandy2818 (Naked Bear)》之铭言:
: ※ 引述《crm123 (CRM)》之铭言:
: : 小弟用list装资料 资料内容类似如下
: : 10day.png
: : 20day.png
: : 20day-1.png
: : 30day.png
: : 40day.png
: : 40day-1.png
: : 40day-2.png
: : 想要做到能够删除类似资料(开头的10、20)
: : 然后重复的(20两笔留-1的、40留-2)
: : 想问有没有什么方法能够达到
: : 谢谢
: :