如何运行一段python代码_Python退出时强制运行一段代码如何实现 Python退出时强制运行一段代码实现方法...
本篇文章小編給大家分享一下Python退出時(shí)強(qiáng)制運(yùn)行一段代碼實(shí)現(xiàn)方法,代碼介紹的很詳細(xì),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家供大家參考,有需要的小伙伴們可以來(lái)看看。
設(shè)想這樣一個(gè)場(chǎng)景,你要給一個(gè)項(xiàng)目開(kāi)發(fā)測(cè)試程序,程序開(kāi)始運(yùn)行的時(shí)候,會(huì)創(chuàng)建初始環(huán)境,測(cè)試完成以后,會(huì)清理環(huán)境。
這段邏輯本身非常簡(jiǎn)單:
setup()
test()
clean()
但由于測(cè)試的代碼比較復(fù)雜,你總是在調(diào)試的時(shí)候程序異常,導(dǎo)致每次clean()函數(shù)還沒(méi)有來(lái)得及運(yùn)行,程序就崩潰了。
你可能想到,如果這樣寫會(huì)怎么樣呢:
setup()
try:
text()
except Exception as e:
print('運(yùn)行異常:', e)
clean()
似乎看起來(lái),程序一定會(huì)運(yùn)行到clean()函數(shù),但是,如果你代碼寫的多,你就應(yīng)該知道,濫用try...except...會(huì)讓你非常痛苦。例如它突然給你打印一個(gè)運(yùn)行異常:
1。你根本不知道是哪里出了問(wèn)題,也不知道具體出了什么問(wèn)題。為了找到問(wèn)題,你必須讓程序把錯(cuò)誤爆出來(lái)。但這樣一來(lái),clean()又不能正常運(yùn)行了。
有什么辦法,既能讓程序報(bào)錯(cuò),又能在報(bào)錯(cuò)已經(jīng)還能運(yùn)行clean()呢?
這個(gè)時(shí)候,我們就可以使用Python自帶的atexit這個(gè)模塊了。它的使用方法非常簡(jiǎn)單:
import atexit
@atexit.register
def clean():
print('清理環(huán)境相關(guān)的代碼')
setup()
test()
這樣一來(lái),我們不需要顯式調(diào)用clean函數(shù)了。無(wú)論程序正常結(jié)束,還是程序異常報(bào)錯(cuò),clean函數(shù)里面的內(nèi)容總會(huì)執(zhí)行。
如下圖所示:
atexit使用中有下面幾個(gè)注意事項(xiàng):
你可以注冊(cè)多個(gè)退出函數(shù),他們會(huì)按照注冊(cè)時(shí)間從晚到早以此執(zhí)行。例如:
import atexit
@atexit.register
def clean_1():
...
@atexit.register
def clean_2():
...
會(huì)先運(yùn)行clean_2()后運(yùn)行clean_1()
如果clean()函數(shù)有參數(shù),那么你可以不用裝飾器,而是直接調(diào)用atexit.register(clean_1, 參數(shù)1, 參數(shù)2, 參數(shù)3='xxx')。
如果程序是被你沒(méi)有處理過(guò)的系統(tǒng)信號(hào)殺死的,那么注冊(cè)的函數(shù)無(wú)法正常執(zhí)行。
如果發(fā)生了嚴(yán)重的Python內(nèi)部錯(cuò)誤,你注冊(cè)的函數(shù)無(wú)法正常執(zhí)行。
如果你手動(dòng)調(diào)用了os._exit(),你注冊(cè)的函數(shù)無(wú)法正常執(zhí)行。
總結(jié)
以上是生活随笔為你收集整理的如何运行一段python代码_Python退出时强制运行一段代码如何实现 Python退出时强制运行一段代码实现方法...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python什么模块动态调用链接库_py
- 下一篇: .mb是什么文件_神经网络长什么样不知道