Python 程序報(bào)錯(cuò)崩潰后如何倒回到崩潰的位置(推薦)
假設(shè)我們有一段程序,從 Redis 中讀取數(shù)據(jù),解析以后提取出里面的 name 字段:
import json import redis client = redis.Redis() def read(): while True: data = client.lpop('info') if data: yield json.loads(data) else: break def parse(): for data in self.read(): print(data['name']) if __name__ == '__main__': parse()
代碼的邏輯本身很簡(jiǎn)單,從 Redis 中一條一條讀取數(shù)據(jù),讀到的數(shù)據(jù)是 JSON 字符串,所以先使用json.loads解析成字典。然后讀取字典中的name對(duì)應(yīng)的值。一直讀到Redis 列表為空。
我們運(yùn)行一下看看:
報(bào)錯(cuò)了,說明Redis 中的某一條數(shù)據(jù)有問題。你想看看這條有問題的數(shù)據(jù),但是現(xiàn)在程序已經(jīng)崩潰了,進(jìn)程結(jié)束了,這條有問題的數(shù)據(jù)也就永久丟失了。你再也不可能知道它長(zhǎng)什么樣了。
玩過《火焰紋章-風(fēng)花雪月》的朋友都知道,主角有一個(gè)技能叫做天刻之脈動(dòng),如果隊(duì)友死了,他可以逆轉(zhuǎn)時(shí)間,回到隊(duì)友被殺之前,從而改變隊(duì)友的命運(yùn)。
那么,在Python里面我們有沒有什么辦法讓程序起死回生,看到當(dāng)初導(dǎo)致程序報(bào)錯(cuò)的那一行代碼呢?如果你是使用python3 xxx.py運(yùn)行的程序,那么確實(shí),除非你能重新導(dǎo)入剛才的數(shù)據(jù),否則無(wú)法知道。
但是,如果你是使用如下命令:python3 -i xxx.py啟動(dòng)的程序,那么世界就不一樣了,你的程序獲得了起死回生的能力。你可以重新回到事故現(xiàn)場(chǎng)。
我們恢復(fù)一下 Redis 的數(shù)據(jù)(當(dāng)然,在生產(chǎn)環(huán)境里面你可能就沒有辦法恢復(fù)了。但現(xiàn)在寫文章的示例數(shù)據(jù),我還是可以回復(fù)的^_^)
然后使用python3 -i read_name.py重新運(yùn)行這個(gè)程序:
可以看到,現(xiàn)在雖然程序崩潰了,但是卻出現(xiàn)了 Python 的交互環(huán)境。進(jìn)程并沒有完全退出。這樣一來,我們就可以輸入魔法指令,讓程序倒退回到報(bào)錯(cuò)的那個(gè)地方。輸入命令:
import pdbpdb.pm()
運(yùn)行效果如下圖所示:
現(xiàn)在,我們已經(jīng)回到了報(bào)錯(cuò)的那一行了。報(bào)錯(cuò)報(bào)的是data這個(gè)字典沒有name這個(gè) key,那么我們就來看看這個(gè)字典里面有什么,直接輸入變量名data:
原來,這一條有問題的數(shù)據(jù),是把name寫成了name1。
總結(jié)
pdb是Python自帶的調(diào)試工具。我們使用的PyCharm的調(diào)試功能,也是基于pdb實(shí)現(xiàn)的。
到此這篇關(guān)于Python 程序報(bào)錯(cuò)崩潰后如何倒回到崩潰的位置的文章就介紹到這了,更多相關(guān)Python 程序報(bào)錯(cuò)崩潰內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python 如何調(diào)試程序崩潰錯(cuò)誤
- jupyter notebook 使用過程中python莫名崩潰的原因及解決方式
- python實(shí)現(xiàn)監(jiān)控某個(gè)服務(wù) 服務(wù)崩潰即發(fā)送郵件報(bào)告
- 解決python多線程報(bào)錯(cuò):AttributeError: Can''t pickle local object問題
- Python3下錯(cuò)誤AttributeError: ‘dict’ object has no attribute’iteritems‘的分析與解決
- python錯(cuò)誤:AttributeError: ''module'' object has no attribute ''setdefaultencoding''問題的解決方法
- Python進(jìn)程崩潰AttributeError異常問題解決
相關(guān)文章
python sklearn數(shù)據(jù)預(yù)處理之正則化詳解
數(shù)據(jù)的預(yù)處理是數(shù)據(jù)分析,或者機(jī)器學(xué)習(xí)訓(xùn)練前的重要步驟,這篇文章主要為大家詳細(xì)介紹了sklearn數(shù)據(jù)預(yù)處理中正則化的相關(guān)知識(shí),需要的可以參考下2023-10-10python找出因數(shù)與質(zhì)因數(shù)的方法
這篇文章主要介紹了python找出因數(shù)與質(zhì)因數(shù)的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Python自動(dòng)打印被調(diào)用函數(shù)變量名及對(duì)應(yīng)值?
這篇文章主要介紹了Python自動(dòng)打印被調(diào)用函數(shù)的變量名及對(duì)應(yīng)的值,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià),需要的朋友可以參考一下?2022-07-07Python3+selenium實(shí)現(xiàn)cookie免密登錄的示例代碼
這篇文章主要介紹了Python3+selenium實(shí)現(xiàn)cookie免密登錄的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03python中CURL 和python requests的相互轉(zhuǎn)換實(shí)現(xiàn)
本文主要介紹了python中CURL 和python requests的相互轉(zhuǎn)換實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03Python實(shí)現(xiàn)學(xué)生管理系統(tǒng)并生成exe可執(zhí)行文件詳解流程
由于Python都會(huì)了,學(xué)校教的確實(shí)基礎(chǔ),平時(shí)就沒怎么去上課,讓美女老師天天腦殼痛,這不快畢業(yè)了,讓我做一個(gè)學(xué)生管理系統(tǒng)出來,還要打包成exe發(fā)給她,她就不追究我不上課的問題了2022-01-01Python Opencv 通過軌跡(跟蹤)欄實(shí)現(xiàn)更改整張圖像的背景顏色
這篇文章主要介紹了Python Opencv 通過軌跡(跟蹤)欄實(shí)現(xiàn)更改整張圖像的背景顏色,在文章末尾有一個(gè)小訓(xùn)練——是將所學(xué)得的圖像顏色修改應(yīng)用為畫板一般的刷新,需要的朋友可以參考下2020-03-03Python 快速驗(yàn)證代理IP是否有效的方法實(shí)現(xiàn)
有時(shí)候,我們需要用到代理IP,比如在爬蟲的時(shí)候,不知道怎么驗(yàn)證這些IP是不是有效的,本文就介紹一下,感興趣的可以了解一下2021-07-07