为了实现python程序的自删功能查了很多资料,最终使用了这个方案
代码部分
def run_batch_file(file_path): # 执行bat文件函数
Popen(file_path, creationflags=subprocess.CREATE_NEW_CONSOLE)
def zh():
pf=os.getenv("SystemDrive") #获取系统盘 盘符
file = open(pf+r'\Users\%s\Desktop\1.bat' % getpass.getuser(), 'w') # 生成bat文件 坑,win开机自启的程序会在根目录运行无法创建文件 ,使用绝对路径
file.write('@echo off\ndel %s\win\win.exe\ndel %%0' % pf) # 写入bat代码
file.close() # 关闭文件,不关闭的话无法运行
run_batch_file(pf+r'\Users\%s\Desktop\1.bat' % getpass.getuser()) # 程序结束前运行bat文件 文件路径只能写死写绝对路径,没办法,win设置自启之后开机运行后台进程的当前路径是根目录,就相当于他在根目录里面运行
sys.exit() # 结束程序
生成一个bat文件,删除路径指向python程序自身,在程序退出语句前生成并执行这个bat文件,程序结束后就会自动删除自己,bat脚本也可以实现自删,这样就完美的自我删除不留痕迹了
新问题
但这里会涉及到一个问题,我们都知道一个程序在运行的时候是无法删掉的,如果bat脚本的执行速度过快,程序退出过慢,就会导致程序还没退出就开始执行bat脚本了,就会删不掉
这里刚好也遇到了这个问题,我发现有一些库会导致程序退出时间增加,比如tkinter,可能是毫秒级别的肉眼无法察觉,但打包运行的时候就出问题了,程序退出比bat脚本执行的速度慢了,就没法自删了
解决办法
既然程序退出慢那就只能让bat脚本执行速度比程序退出更慢了,在bat脚本第一行加入
ping -n 3 127.0.0.1>nul
这样可以让bat脚本延迟3秒后执行,3秒足够了,这样就又可以正常自删了