在程序退出前做一些事情

2025-02-27 09:07:00
admin
原创
26
摘要:问题描述:如何让某个函数或某个东西在程序退出前执行?我有一个脚本会在后台持续运行,我需要它在退出前将一些数据保存到文件中。有没有标准的方法来做到这一点?解决方案 1:检查atexit模块:http://docs.python.org/library/atexit.html例如,如果我想在应用程序终止时打印一条...

问题描述:

如何让某个函数或某个东西在程序退出前执行?我有一个脚本会在后台持续运行,我需要它在退出前将一些数据保存到文件中。有没有标准的方法来做到这一点?


解决方案 1:

检查atexit模块:

http://docs.python.org/library/atexit.html

例如,如果我想在应用程序终止时打印一条消息:

import atexit

def exit_handler():
    print 'My application is ending!'

atexit.register(exit_handler)

请注意,这对于脚本的正常终止非常有效,但并非在所有情况下都会被调用(例如致命的内部错误)。

解决方案 2:

如果您希望某些东西始终运行,即使出现错误,也可以try: finally:这样使用 -

def main():
    try:
        execute_app()
    finally:
        handle_cleanup()

if __name__=='__main__':
    main()

如果你还想处理异常,你可以except:finally:

解决方案 3:

KeyboardInterrupt如果您通过引发异常(例如按 Ctrl-C)来停止脚本,则可以将其作为标准异常进行捕获。您也可以SystemExit用同样的方式进行捕获。

try:
    ...
except KeyboardInterrupt:
    # clean up
    raise

我提到这一点只是为了让你了解它;做到这一点的“正确”方法是atexit上面提到的模块。

解决方案 4:

这可以处理正常退出以及使用kill或终止进程Ctrl+C

import sys
import atexit
import signal

def exit_handler():
    print("Cleaning up")

def kill_handler(*args):
    sys.exit(0)

atexit.register(exit_handler)
signal.signal(signal.SIGINT, kill_handler)
signal.signal(signal.SIGTERM, kill_handler)

# MAIN PROGRAM
# for example just reading from the input:
input("Press enter: ")

解决方案 5:

这是根据其他答案改编的版本。它应该可以正常退出、终止和 PyCharm 停止按钮(我可以确认的最后一个)工作(未经全面测试)。

import signal
import atexit


def handle_exit(*args):
    try:
        ... do computation ...
    except BaseException as exception:
        ... handle the exception ...


atexit.register(handle_exit)
signal.signal(signal.SIGTERM, handle_exit)
signal.signal(signal.SIGINT, handle_exit)

解决方案 6:

如果您拥有在程序的整个生命周期内都存在的类对象,那么您也可以使用该__del__(self)方法从类中执行命令:

class x:
def __init__(self):
    while True:
        print ("running")
        sleep(1)

def __del__(self):
    print("destructuring")


a = x()

如果执行中止,这在正常程序端也有效,肯定会有一些例外:

running
running
running
running
running
Traceback (most recent call last):
  File "x.py", line 14, in <module>
    a = x()
  File "x.py", line 8, in __init__
    sleep(1)
KeyboardInterrupt
destructuring

解决方案 7:

您还可以使用上下文管理器来做类似于@Brian C. Lane 的答案的事情:

from contextlib import closing


class RunThat:
    def __init__(self) -> None:
        pass

    def execute_app(self) -> None:
        print("computation")

    def close(self) -> None:
        print("handle_cleanup")


with closing(RunThat()) as rt:
    rt.execute_app()

# --- which results in
# computation
# handle_cleanup
相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1289  
  IPD(Integrated Product Development)流程作为一种先进的产品开发管理模式,在众多企业中得到了广泛应用。其中,技术评审(TR,Technical Review)环节至关重要,它不仅是对技术方案的评估,更是激发创新思维、推动产品创新的关键节点。深入理解TR在IPD流程中的创新思维及其应用实践...
IPD流程中TR   9  
  IPD(Integrated Product Development)产品开发流程作为一种先进的产品开发管理模式,在众多企业中得到了广泛应用。它打破了传统产品开发过程中部门之间的壁垒,将市场、研发、生产、销售等各个环节有机整合在一起,形成一个高效协同的整体。通过这种方式,企业能够更快速、更精准地开发出满足市场需求的产品...
IPD管理流程   11  
  IPD(Integrated Product Development)流程作为一种先进的产品开发管理模式,在众多企业中得到了广泛应用。其中,技术评审(TR,Technical Review)环节在整个IPD流程里占据着关键位置,对项目的成功有着深远影响。深入探讨TR与项目成功的关系,有助于企业更好地运用IPD流程,提升...
IPD项目管理   8  
  IPD研发管理体系旨在打破部门墙,实现跨部门协同,确保产品开发以市场和客户需求为导向,高效、高质量地推出满足市场需求的产品。在这一体系下,产品创新可拆解为三个关键步骤,它们环环相扣,共同推动企业的产品不断迭代升级,在激烈的市场竞争中占据优势。这三个步骤分别聚焦于洞察市场机会、规划产品战略以及执行开发与验证,每一步都蕴含...
IPD框架   10  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用