首页 > 解决方案 > Python:重新启动脚本并在功能不起作用后退出它

问题描述

运行后,系统会询问用户是要结束程序 [with sys.exit()] 还是重新启动程序 [ os.system('main.py')]。
如果他重新启动程序,程序将一直运行,直到他可以再次决定是重新启动还是退出。
然而,如果用户想要结束程序,这是不可能的,无论如何都会重新启动程序。
quit()exit()不工作。

这是要求用户重新启动或退出的提示:

while (res := input("Do you want to play again [1] oder exit[2]?\n").lower()) not in {"1", "2"}:
    pass
if res == "1":
    os.system('main.py')
else:
    end_game = True  # Stops the loop, but is not necessary
    print("Sys.exit game")
    sys.exit(0)

当我使用subprocess.call(sys.executable + ' "' + os.path.realpath(__file__) + '"')时,
退出程序有效,但程序并没有真正重新启动[开始时设置为 0 的变量不在 0 处]。

小注意,reboot会重启另一个py文件(main.py),也就是主文件,内容如下:

class main:
    game_logic()

if __name__ == '__main__':
    main()

game_logic() 是来自另一个 Py 文件的函数,其中重新启动和退出的查询是。

标签: pythonexitrestartsysos.system

解决方案


import os
import sys 

while (res := input("Do you want to play again [1] oder exit[2]?\n").lower()) not in {"1", "2"}:
    pass
if res == "1":
    python = sys.executable
    os.execl(python, python, * sys.argv)
else:
    end_game = True  # Stops the loop, but is not necessary
    print("Sys.exit game")
    sys.exit(0)

class main:
    game_logic()

if __name__ == '__main__':
    main()
        

上面的例子应该适合你。您应该使用os.execl(...)而不是os.system(...). 最后一个以递归方式创建新进程,并可能导致内存不足问题。您不应该创建新流程,而是希望用新流程替换当前流程。这可以通过家人的execl()电话或其他电话来完成。exec

要正确理解它,您可能需要查看此处。它指的是 C 语言,但它是一样的,因为 Python 是围绕本地调用。

与所有 exec 函数一样,execv 用新的进程映像替换调用进程映像。这具有使用调用进程的进程 ID 运行新程序的效果。注意没有启动一个新进程;新的过程映像只是简单地覆盖了原始过程映像。execv 函数最常用于覆盖通过调用 fork 函数创建的进程映像。


推荐阅读