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