導航:首頁 > 編程語言 > python致命錯誤

python致命錯誤

發布時間:2022-04-27 15:18:56

python運行錯誤怎麼辦

  1. 一、python的錯誤處理:

    在程序運行的過程中,如果發生了錯誤,可以事先約定返回一個錯誤代碼,這樣,就可以知道是否有錯以及出錯的原因。
    在操作系統提供的調用中,返回錯誤碼非常常見。比如打開文件的函數open(),成功時返迴文件的描述符(就是一個整數),出錯時返回-1用錯誤碼來表示是否出錯十分不便,因為函數本身應該返回的正常結果和錯誤碼混在一起,造成調用者必須大量的代碼來判斷是否出錯:def foo():
    r = somefunction() if r == (-1): return (-1) return rdef bar():
    r = foo() if r == (-1): print("Error") else: pass一旦出錯,還要一級一級上報,直到某個函數可以處理該錯誤(比如,給用戶輸出一個錯誤信息)

    所以,高級語言通常都內置了一套try...except...finally...的錯誤處理機制,python也不例外。try
    讓我們用一個例子來看看try的機制try: print("try....")
    r = 10 / 0 print("result", r)except ZeroDivisionError as e: print("except:", e)finally: print("finally...")print("END....")

    當我們認為某些代碼可能會出錯時,就可以用try來運行這段代碼,如果執行出錯,則後續代碼不會繼續執行
    而是直接跳轉至錯誤處理代碼,即except語句塊
    執行完except後,如果有finally語句塊,則執行finally語句塊,至此,執行完畢。

    上面的代碼在計算10 / 0時 會產生一個除法運算錯誤:try....except: division by zerofinally...
    END....>>>從輸出可以看到,當錯誤發生時,後續語句print("result:", r)不會被執行,except由於捕獲到ZeroDivisionError因此被執行。
    最後,finally語句被執行。然後,程序繼續按照流程往下走。

    如果把除數0 變成2,則執行結果如下try....
    result 5.0finally...
    END....>>>由於沒有錯誤發生,所以except語句塊不會被執行,但是finally如果有則一定會被執行,當然finally也可以沒有
    你還可以猜測,錯誤應該有很多種類,日過發生了不同類型的錯誤,應該由不同的except語句塊處理。
    沒錯,可以有多個except來捕獲不同類型的錯誤:try: print("try.....")
    r = 10 / int("a") print("result:", r)except ValueError as e: print("ValueError:", e)except ZeroDivisionError as e: print("ZeroDivisionError:", e)finally: print("finally...")print("END...")

    int()函數可能會拋出ValueError,所以我們用一個except捕獲ValueError,用另一個except捕獲ZeroDivisionError
    此外,如果沒有錯誤發生,可以再except語句塊後面加一個else,當沒有錯誤發生時,會自動執行else語句。try: print("try...")
    r = 10 / int("2") print("result:", r)except ValueError as e: print("ValueError:", e)except ZeroDivisionError as e: print("ZeroDivisionError:", e)else: print("No error!")finally: print("finally...")print("END")

    python的錯誤其實也是class,所有的錯誤類型都繼承自BaseException,
    所以在使用except時需要注意的是,它不但捕獲該類型的錯誤,還把其子類也「一網打盡」。
    比如:try:
    foo()except ValueError as e: print("ValueError")except UnicodeError as e: print("UnicodeError")

    第二個except永遠也捕獲不到UnicodeError, 因為UnicodeError是ValueError的子類
    如果有,也是被第一個except給捕獲了。
    python所有的錯誤都是BaseException類派生的。

    所有常見的錯誤類型和繼承關系看這里:
    https://docs.python.org/3/library/exceptions.html#exception-hierarchy使用try...exccept捕獲錯誤還有一個巨大的好處,就是可以跨越多層調用,比如函數main()調用foo()
    foo()調用bar(),結果bar()出錯了,這時,只要main()捕獲到了,就可以處理:def foo(s): return 10 / int(s)def bar(s): return foo(s) * 2def main(): try:
    bar("0") except Exception as e: print("Error:", e) finally: print("finally...")

    也就是說,不需要在每個可能出錯的地方去捕獲異常,只要在合適的層次去捕獲就可以了。
    這樣一來,就大大減少了寫 try...except...finally的麻煩。


    二、調用堆棧

    如果錯誤沒有被捕獲,他就會一直往上拋,最後被python解釋器捕獲,列印一個錯誤信息,然後程序退出。def foo(s): return 10 / int(s)def bar(s): return foo(s) * 2def main():
    bar("0")

    main()

    執行結果為:

    Traceback (most recent call last):
    File "C:/Python36/test.py", line 10, in <mole>
    main()
    File "C:/Python36/test.py", line 8, in main
    bar("0")
    File "C:/Python36/test.py", line 5, in bar return foo(s) * 2
    File "C:/Python36/test.py", line 2, in foo return 10 / int(s)
    ZeroDivisionError: division by zero

    出錯並不可怕,可怕的時不知道哪裡出錯了。解讀錯誤信息時定位錯誤的關鍵。
    我們從上往下可以看到整個錯誤的調用函數鏈。

    錯誤第一行:
    Traceback (most recent call last):
    這告訴我們的是錯誤的跟蹤信息。

    File "C:/Python36/test.py", line 10, in < mole >main()
    說明調用main()出錯了,在代碼文件test.py中第10行,但是原因是第8行:

    File"C:/Python36/test.py", line8, in main
    bar("0")
    調用bar("0")出錯了,在代碼文件test.py中第8行,但原因是第5行:


    File"C:/Python36/test.py", line5, in barreturn foo(s) * 2調用return foo(s) * 2時出錯了,在test.py中第5行,但原因是第2行


    File "C:/Python36/test.py", line 2, in foo return 10 / int(s)
    ZeroDivisionError: division by zero

    這時我們找到了源頭,原來在第2行調用return 10 / int(s)出錯了,錯誤為ZeroDivisionError


    三、記錄錯誤

    如果不捕獲錯誤,自然可以讓python解釋器來列印出錯誤堆棧,但是程序也被結束了。
    既然我們能捕獲錯誤,就可以把錯誤堆棧列印出來,然後分析錯誤原因,同時,讓程序繼續執行下去。

    python內置的logging模塊可以非常容易地記錄錯誤信息:import loggingdef foo(s): return 10 / int(s)def bar(s): return foo(s) * 2def main(): try:
    bar("0") except Exception as e:
    logging.exception(e)

    main()print("END")

    輸出結果為:
    ERROR:root:division by zero
    Traceback (most recent call last):
    File "C:/Python36/test.py", line 12, in main
    bar("0")
    File "C:/Python36/test.py", line 8, in bar return foo(s) * 2
    File "C:/Python36/test.py", line 5, in foo return 10 / int(s)
    ZeroDivisionError: division by zero
    END

    同樣是出錯,但程序列印完錯誤信息後會繼續執行,並正常退出。

    通過配置,logging還可以把錯誤記錄到日誌文件里,方便事後排查。


    四、拋出錯誤

    因為錯誤是class,捕獲一個錯誤就是捕獲到該class的一個實例。
    因此,錯誤並不是憑空產生的,而是有意創建並拋出的。

    python的內置函數會拋出很多類型的錯誤,我們自己編寫的函數也可以拋出錯誤。

    如果要拋出錯誤,首先根據需要,可以定義一個錯誤的class,選擇好繼承關系,然後用raise語句拋出一個錯誤的實例:class FooError(ValueError): passdef foo(s):
    n = int(s) if n == 0: raise FooError("invalid value: %s" % s) return 10 / n

    foo("0")

    輸出結果:
    Traceback (most recent call last):
    File "C:/Python36/test.py", line 10, in <mole>
    foo("0")
    File "C:/Python36/test.py", line 7, in foo raise FooError("invalid value: %s" % s)
    FooError: invalid value: 0

    只有在必要的時候才定義我們自己的錯誤類型。
    如果可以選擇python已有的內置錯誤類型(比如ValueError, TypeError),盡量使用python內置的錯誤類型。

    最後,我們來看另一種錯誤處理方式:def foo(s):
    n = int(s) if n == 0: raise ValueError("invalid value: %s" % s) return 10 / ndef bar(): try:
    foo("0") except ValueError as e: print("ValieError") raisebar()

    在bar()函數中,我們明明已經捕獲了錯誤,但是,列印一個ValueError之後
    又通過raise語句拋出去了。這不是有病嗎

    其實,這種錯誤處理方式不但沒病,而且相當常見。
    捕獲錯誤目的只是記錄一下,便於或許追蹤。

    但是,由於當前函數不知道應該怎麼處理該錯誤,所以,最恰當的方式是繼續往上拋,讓頂層調用者去處理。
    好比一個員工處理不了一個問題時,就把問題一直往上拋,最終會拋給CEO去解決。

    注意:raise語句如果不帶參數,就會把當前錯誤原樣拋出。
    此外,在except中raise一個Error,還可以改寫錯誤類型try: 10 / 0except ZeroDivisionError: raise ValueError("do not input zero!")

    輸出結果:
    Traceback (most recent call last):
    File "C:/Python36/test.py", line 4, in <mole> raise ValueError("do not input zero!")
    ValueError: do not input zero!>>>只要是合理的轉換邏輯就可以,但是,絕不應該把一個IOError轉成毫不相乾的valueError.

    總結:

    python內置的 try...except...finally 用來處理錯誤十分方便。
    出錯時,會分析錯誤信息並定位錯誤發生的代碼位置才是關鍵的。

    程序也可以主動拋出錯誤,讓調用者來處理相應的錯誤。
    但是應該在文檔中寫清楚可能會拋出哪些錯誤,以及錯誤產生的原因。

㈡ python出現這個錯誤是什麼原因

搜集了一些python最重要的內建異常類名,並做了簡單的介紹:

AttributeError:屬性錯誤,特性引用和賦值失敗時會引發屬性錯誤

NameError:試圖訪問的變數名不存在

SyntaxError:語法錯誤,代碼形式錯誤

Exception:所有異常的基類,因為所有python異常類都是基類Exception的其中一員,異常都是從基類Exception繼承的,並且都在exceptions模塊中定義。

IOError:一般常見於打開不存在文件時會引發IOError錯誤,也可以解理為輸出輸入錯誤

KeyError:使用了映射中不存在的關鍵字(鍵)時引發的關鍵字錯誤

IndexError:索引錯誤,使用的索引不存在,常索引超出序列范圍,什麼是索引

TypeError:類型錯誤,內建操作或是函數應於在了錯誤類型的對象時會引發類型錯誤

ZeroDivisonError:除數為0,在用除法操作時,第二個參數為0時引發了該錯誤

ValueError:值錯誤,傳給對象的參數類型不正確,像是給int()函數傳入了字元串數據類型的參數

㈢ 如何解決python -v 報錯問題

解決python -v報錯問題的方法:

在cmd命令行中輸入「python -v」報錯是因為沒有將python的安裝路徑添加到系統環境變數path中,將python的安裝路徑添加進去就可以了

示例如下:

輸入python -v結果:

更多Python知識,請關註:Python自學網!!

㈣ Python 運行報錯NameError出現原因,怎麼解決

python程序,報錯NameError: name XX is not defined 是沒有聲明造成的,需要在文件的前兩行進行聲明編碼,聲明方法為:

1、寫一個python文件,文件中有中文字元,且未聲明編碼。

㈤ Python使用pip出現致命錯誤

去python路徑下搜索一下pip,有可能有pip3之類的可以用

㈥ python錯誤

異常名稱 異常說明
AssertionError 斷言語句(assert)失敗
AttributeError 嘗試訪問未知的對象屬性
EOFError 用戶輸入文件末尾標志EOF(Ctrl+d)
FloatingPointError 浮點計算錯誤
GeneratorExit generator.close()方法被調用的時候
ImportError 導入模塊失敗的時候
IndexError 索引超出序列的范圍
KeyError 字典中查找一個不存在的關鍵字
KeyboardInterrupt 用戶輸入中斷鍵(Ctrl+c)
MemoryError 內存溢出(可通過刪除對象釋放內存)
NameError 嘗試訪問一個不存在的變數
NotImplementedError 尚未實現的方法
OSError 操作系統產生的異常(例如打開一個不存在的文件)
OverflowError 數值運算超出最大限制
ReferenceError 弱引用(weak reference)試圖訪問一個已經被垃圾回收機制回收了的對象
RuntimeError 一般的運行時錯誤
StopIteration 迭代器沒有更多的值
SyntaxError Python的語法錯誤
IndentationError 縮進錯誤
TabError Tab和空格混合使用
SystemError Python編譯器系統錯誤
SystemExit Python編譯器進程被關閉
TypeError 不同類型間的無效操作
UnboundLocalError 訪問一個未初始化的本地變數(NameError的子類)
UnicodeError Unicode相關的錯誤(ValueError的子類)
UnicodeEncodeError Unicode編碼時的錯誤(UnicodeError的子類)
UnicodeDecodeError Unicode解碼時的錯誤(UnicodeError的子類)
UnicodeTranslateError Unicode轉換時的錯誤(UnicodeError的子類)
ValueError 傳入無效的參數
ZeroDivisionError 除數為零

㈦ python報錯no mole named是什麼

原因及解決方法如下:

(1)如果'×××'是一些python包,比如說numpy、pandas等,這時候在終端輸入pip install ×××命令安裝相應的包即可。

(2)如果'×××'是非python的包, 比如說自己寫了個alice.py文件,然後在bob.py的文件里要調用a,即import alice或者from alice import,這時候如果報錯No mole named '×××'的話,是因為系統找不到alice.py這個文件。

解決方法:為python解釋器指定搜索路徑,即把alice的路徑添加到環境變數里。可以在bob.py文件的開始加入以下代碼,並使得alice.py在root_path路徑下。

Python由荷蘭數學和計算機科學研究學會的Guido van Rossum於1990 年代初設計,作為一門叫做ABC語言的替代品。

Python提供了高效的高級數據結構,還能簡單有效地面向對象編程。Python語法和動態類型,以及解釋型語言的本質,使它成為多數平台上寫腳本和快速開發應用的編程語言,隨著版本的不斷更新和語言新功能的添加,逐漸被用於獨立的、大型項目的開發。

Python解釋器易於擴展,可以使用C或C++(或者其他可以通過C調用的語言)擴展新的功能和數據類型。Python 也可用於可定製化軟體中的擴展程序語言。Python豐富的標准庫,提供了適用於各個主要系統平台的源碼或機器碼。

㈧ 運行python時代碼一直報錯怎麼辦

看上去是伺服器本身出現了錯誤,返回500錯誤碼,先用瀏覽器進行訪問測試,如果沒有錯誤可以試試使用代碼模擬瀏覽器,加上header。

㈨ python運行報錯

錯誤的原因是user這個變數從未被定義過,所以執行失敗了。從你的代碼中看,只需要將「user.」刪除掉就能運行了。

㈩ python下載 pygame時顯示啟動程序中的致命錯誤

請問你可以截個圖嗎?

ps:是這樣的:

C:Program FilesPython36Scriptspip install (此處填pygame文件的路徑和全名!)

e.g:win64-installer-pygame.whl

閱讀全文

與python致命錯誤相關的資料

熱點內容
壓縮機異音影響製冷嗎 瀏覽:711
德斯蘭壓縮機 瀏覽:490
程序員太極拳視頻 瀏覽:531
網上購買加密鎖 瀏覽:825
安卓為什麼軟體要隱私 瀏覽:83
虛擬主機管理源碼 瀏覽:811
java圖形圖像 瀏覽:230
單片機輸出口電平 瀏覽:486
java配置資料庫連接 瀏覽:479
java多態的體現 瀏覽:554
java的split分隔符 瀏覽:128
跪著敲代碼的程序員 瀏覽:238
web和php有什麼區別 瀏覽:120
加密的電梯卡怎麼復制蘋果手機 瀏覽:218
warez壓縮 瀏覽:137
黑馬程序員培訓機構官網天津 瀏覽:904
mainjavasrc 瀏覽:58
如何買伺服器挖礦 瀏覽:292
php批量上傳文件夾 瀏覽:560
安卓固件怎麼更新 瀏覽:169