當(dāng)我們寫的一個腳本或程序發(fā)生各種不可預(yù)知的異常時,如果我們沒有進(jìn)行捕獲處理的時候,通常都會致使程序崩潰退出,并且會在終端打印出一堆密密麻麻的traceback堆棧信息來告訴我們,是哪個地方出了問題。
為江北等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及江北網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、江北網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
上面這段 traceback
那有沒有一種辦法,可以解決這些問題呢?
當(dāng)然有了,在 Python 中,沒有什么問題是一個庫解決不了的,如果有,那就等你去開發(fā)這個庫。
今天要介紹的這個庫呢,叫做 pretty-errors
,從名字上就可以知道它的用途,是用來美化錯誤信息的。
通過這條命令你可以安裝它
$ python3 -m pip install pretty-errors
由于使用了 pretty-errors
后,你的 traceback 信息輸出,會有代碼高亮那樣的效果,因此當(dāng)你在使用測試使用 pretty-error
時,請確保你使用的終端可以輸出帶有顏色的字體。
在 windows 上你可以使用 Powershell,cmder 等
在 Mac 上你可以使用自帶的終端,或者安裝一個更好用的 iTerm2
隨便寫一個沒有使用 pretty-errors ,并且報(bào)錯了的程序,是這樣子的。
而使用了 pretty_errors 后,報(bào)錯信息被美化成這樣了。
是不是感覺清楚了不少,那種密密麻麻帶來的焦慮感是不是都消失了呢?
當(dāng)然這段代碼少,你可能還沒感受到,那就來看下 該項(xiàng)目在 Github上的一張效果對比圖吧
可以看到使用了 pretty_errors 后,無非就是把過濾掉了一些干擾我們視線的無用信息,然后把有用的關(guān)鍵信息給我們高亮顯示。
既然既然這樣,那 pretty_errors 應(yīng)該也能支持我們?nèi)绾巫远x我們選用什么樣的顏色,怎么排版吧?
答案是顯而易見的。
pretty_errors 和其他庫不太一樣,在一定程度上(如果你使用全局配置的話),它并不是開箱即用的,你在使用它之前可能需要做一下配置。
使用這一條命令,會讓你進(jìn)行配置,可以讓你在該環(huán)境中運(yùn)行其他腳本時的 traceback 輸出都自動美化。
$ python3 -m pretty_errors
配置完成后,你再運(yùn)行任何腳本,traceback 都會自動美化了。
不僅是在我的 iTerm 終端下
在 PyCharm 中也會
唯一的缺點(diǎn)就是,原先在 PyCharm 中的 traceback 可以直接點(diǎn)擊 文件路徑
直接跳轉(zhuǎn)到對應(yīng)錯誤文件代碼行,而你如果是在 VSCode 可以使用 下面自定義配置的方案解決這個問題(下面會講到,參數(shù)是:display_link
)。
因此,有些情況下,你并不想設(shè)置 pretty_errors
全局可用。
那怎么取消之前的配置呢?
只需要再次輸出 python -m pretty_errors
,輸出入 C
即可清除。
取消全局可用后,你可以根據(jù)自己需要,在你需要使用 pretty-errors
的腳本文件中導(dǎo)入pretty_errors
,即可使用
import pretty_errors
就像這樣
import pretty_errors
def foo():
1/0
if __name__ == "__main__":
foo()
值得一提的是,使用這種方式,若是你的腳本中,出現(xiàn)語法錯誤,則輸出的異常信息還是按照之前的方式展示,并不會被美化。
因此,為了讓美化更徹底,官方推薦你使用 python -m pretty_errors
上面的例子里,我們使用的都是 pretty_errors
的默認(rèn)美化格式,展示的信息并沒有那么全。
比如
如果使用了 pretty_errors
導(dǎo)致異常信息有丟失,那還不如不使用 pretty_errors
呢。
不過,可以告訴你的是,pretty_errors
并沒有你想象的那么簡單。
它足夠開放,支持自定義配置,可以由你選擇你需要展示哪些信息,怎么展示?
這里舉一個例子
import pretty_errors
# 【重點(diǎn)】進(jìn)行配置
pretty_errors.configure(
separator_character = '*',
filename_display = pretty_errors.FILENAME_EXTENDED,
line_number_first = True,
display_link = True,
lines_before = 5,
lines_after = 2,
line_color = pretty_errors.RED + '> ' + pretty_errors.default_config.line_color,
code_color = ' ' + pretty_errors.default_config.line_color,
)
# 原來的代碼
def foo():
1/0
if __name__ == "__main__":
foo()
在你像上面這樣使用 pretty_errrs.configure
進(jìn)行配置時,拋出的的異常信息就變成這樣了。
當(dāng)然了,pretty_errors.configure()
還可以接收很多的參數(shù),你可以根據(jù)你自己的需要進(jìn)行配置。
header_color
:設(shè)置標(biāo)題行的顏色。timestamp_color
:設(shè)置時間戳顏色default_color
:設(shè)置默認(rèn)的顏色filename_color
:設(shè)置文件名顏色line_number_color
:設(shè)置行號顏色。function_color
:設(shè)置函數(shù)顏色。link_color
:設(shè)置鏈接的顏色。在設(shè)置顏色的時候,pretty_errors
提供了一些常用的 顏色常量供你直接調(diào)取。
BLACK
:黑色GREY
:灰色RED
:紅色GREEN
:綠色YELLOW
:黃色BLUE
:藍(lán)色MAGENTA
:品紅色CYAN
:藍(lán)綠色WHITE
:白色而每一種顏色,都相應(yīng)的匹配的 BRIGHT_
變體 和 _BACKGROUND
變體,
其中,_BACKGROUND
用于設(shè)置背景色,舉個例子如下。
line_number_first
lines_before
: 顯示發(fā)生異常處的前幾行代碼lines_after
: 顯示發(fā)生異常處的后幾行代碼display_link
:啟用后,將在錯誤位置下方寫入鏈接,VScode將允許您單擊該鏈接。separator_character
:用于創(chuàng)建標(biāo)題行的字符。默認(rèn)情況下使用連字符。如果設(shè)置為 ''
或者 None
,標(biāo)題將被禁用。display_timestamp
:啟用時,時間戳將寫入回溯頭中。display_locals
啟用后,將顯示在頂部堆??蚣艽a中的局部變量及其值。
display_trace_locals
line_length
:設(shè)置每行的長度,默認(rèn)為0,表示每行的輸出將與控制臺尺寸相匹配,如果你設(shè)置的長度將好與控制臺寬度匹配,則可能需要禁用full_line_newline
,以防止出現(xiàn)明顯的雙換行符。
full_line_newline
:當(dāng)輸出的字符滿行時,是否要插入換行符。
timestamp_function
調(diào)用該函數(shù)以生成時間戳。默認(rèn)值為time.perf_counter
。
top_first
啟用后,堆棧跟蹤將反轉(zhuǎn),首先顯示堆棧頂部。
display_arrow
啟用后,將針對語法錯誤顯示一個箭頭,指向有問題的令牌。
truncate_code
啟用后,每行代碼將被截?cái)嘁赃m合行長。
stack_depth
要顯示的堆棧跟蹤的大條目數(shù)。什么時候0
將顯示整個堆棧,這是默認(rèn)值。
exception_above
啟用后,異常將顯示在堆棧跟蹤上方。
exception_below
:
啟用后,異常顯示在堆棧跟蹤下方。
reset_stdout
啟用后,重置轉(zhuǎn)義序列將寫入stdout和stderr;如果您的控制臺留下錯誤的顏色,請啟用此選項(xiàng)。
filename_display
設(shè)置文件名的展示方式,有三個選項(xiàng): pretty_errors.FILENAME_COMPACT
、pretty_errors.FILENAME_EXTENDED
,或者pretty_errors.FILENAME_FULL
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
分享標(biāo)題:Python中的pretty-errors庫使用方法-創(chuàng)新互聯(lián)
URL地址:http://www.rwnh.cn/article28/ppccp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、服務(wù)器托管、定制網(wǎng)站、品牌網(wǎng)站建設(shè)、自適應(yīng)網(wǎng)站、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容