Šajā apmācībā jūs uzzināsiet, kā rīkoties ar izņēmumiem savā Python programmā, izmantojot try, izņemot un, visbeidzot, ar piemēru palīdzību.
Video: Python izņēmumu apstrāde (mēģiniet … izņemot … beidzot)
Izņēmumi Python
Python ir daudz iebūvētu izņēmumu, kas tiek parādīti, kad programma saskaras ar kļūdu (kaut kas programmā notiek nepareizi).
Kad rodas šie izņēmumi, Python tulks pārtrauc pašreizējo procesu un nodod to izsaukšanas procesam, līdz tas tiek apstrādāts. Ja tā netiks apstrādāta, programma avarēs.
Piemēram, ņemsim vērā programmu, kurā mums ir funkcija, A
kas izsauc funkciju B
, kas savukārt izsauc funkciju C
. Ja izņēmums notiek funkcijā, C
bet netiek apstrādāts C
, izņēmums pāriet uz B
un pēc tam A
.
Ja to nekad neizdodas apstrādāt, tiek parādīts kļūdas ziņojums, un mūsu programma pēkšņi negaidīti apstājas.
Izņēmumu noķeršana Python
Programmā Python izņēmumus var apstrādāt, izmantojot try
paziņojumu.
Kritiskā darbība, kas var izraisīt izņēmumu, tiek ievietota try
klauzulas iekšpusē . Kods, kas apstrādā izņēmumus, ir ierakstīts except
klauzulā.
Tādējādi mēs varam izvēlēties, kādas operācijas veikt, tiklīdz esam pieņēmuši izņēmumu. Šeit ir vienkāršs piemērs.
# import module sys to get the type of exception import sys randomList = ('a', 0, 2) for entry in randomList: try: print("The entry is", entry) r = 1/int(entry) break except: print("Oops!", sys.exc_info()(0), "occurred.") print("Next entry.") print() print("The reciprocal of", entry, "is", r)
Rezultāts
Ieraksts ir Hmm! notika. Nākamais ieraksts. Ieraksts ir 0 Hmm! notika. Nākamais ieraksts. Ieraksts ir 2. Abpusējais skaitlis 2 ir 0,5
Šajā programmā mēs aplūkojam randomList saraksta vērtības. Kā iepriekš minēts, daļa, kas var izraisīt izņēmumu, tiek ievietota try
bloka iekšpusē .
Ja nenotiek izņēmums, except
bloks tiek izlaists un normāla plūsma turpinās (pēdējai vērtībai). Bet, ja rodas kāds izņēmums, to uztver except
bloks (pirmā un otrā vērtība).
Šeit mēs izdrukājam izņēmuma nosaukumu, izmantojot exc_info()
funkciju sys
moduļa iekšpusē . Mēs varam redzēt, ka a
cēloņi ValueError
un 0
cēloņi ZeroDivisionError
.
Tā kā katrs Python izņēmums tiek mantots no bāzes Exception
klases, iepriekšminēto uzdevumu varam veikt arī šādi:
# import module sys to get the type of exception import sys randomList = ('a', 0, 2) for entry in randomList: try: print("The entry is", entry) r = 1/int(entry) break except Exception as e: print("Oops!", e.__class__, "occurred.") print("Next entry.") print() print("The reciprocal of", entry, "is", r)
Šai programmai ir tāda pati izeja kā iepriekš minētajai programmai.
Īpašu izņēmumu noķeršana Python
Iepriekš minētajā piemērā mēs except
klauzulā neminējām nevienu konkrētu izņēmumu .
Šī nav laba programmēšanas prakse, jo tā aptvers visus izņēmumus un katru gadījumu izskatīs vienādi. Mēs varam norādīt, kuri izņēmumi ir except
jāiekļauj klauzulā.
try
Klauzula var būt jebkurš skaits except
klauzulas, lai apstrādātu dažādus izņēmumus, taču tikai viens tiks izpildīts, ja izņēmums notiek.
Mēs varam izmantot vērtību kopu, lai izņēmuma klauzulā norādītu vairākus izņēmumus. Šeit ir pseidokoda piemērs.
try: # do something pass except ValueError: # handle ValueError exception pass except (TypeError, ZeroDivisionError): # handle multiple exceptions # TypeError and ZeroDivisionError pass except: # handle all other exceptions pass
Izņēmumu palielināšana Python
Python programmēšanā izņēmumi tiek izvirzīti, kad izpildlaikā rodas kļūdas. Izmantojot raise
atslēgvārdu, mēs varam arī manuāli palielināt izņēmumus .
Mēs varam pēc izvēles nodot vērtības izņēmumam, lai paskaidrotu, kāpēc šis izņēmums tika izvirzīts.
>>> raise KeyboardInterrupt Traceback (most recent call last):… KeyboardInterrupt >>> raise MemoryError("This is an argument") Traceback (most recent call last):… MemoryError: This is an argument >>> try:… a = int(input("Enter a positive integer: "))… if a <= 0:… raise ValueError("That is not a positive number!")… except ValueError as ve:… print(ve)… Enter a positive integer: -2 That is not a positive number!
Python mēģiniet ar citu klauzulu
Dažās situācijās, iespējams, vēlēsities palaist noteiktu koda bloku, ja iekšējais koda bloks try
darbojās bez kļūdām. Šādos gadījumos else
ar try
paziņojumu varat izmantot izvēles atslēgvārdu .
Piezīme . Kārtas klauzulas izņēmumus iepriekšējie neizskata, izņemot klauzulas.
Apskatīsim piemēru:
# program to print the reciprocal of even numbers try: num = int(input("Enter a number: ")) assert num % 2 == 0 except: print("Not an even number!") else: reciprocal = 1/num print(reciprocal)
Rezultāts
Ja mēs izturēsim nepāra skaitli:
Ievadiet skaitli: 1 Nav pāra skaitlis!
Ja mēs izturam pāra skaitli, tiek aprēķināts un parādīts abpusējais skaitlis.
Ievadiet skaitli: 4 0,25
Tomēr, ja mēs nokārtojam 0, mēs saņemam, ZeroDivisionError
jo koda bloks iekšpusē else
netiek apstrādāts ar iepriekšējo except
.
Enter a number: 0 Traceback (most recent call last): File "", line 7, in reciprocal = 1/num ZeroDivisionError: division by zero
Python try… finally
The try
statement in Python can have an optional finally
clause. This clause is executed no matter what, and is generally used to release external resources.
For example, we may be connected to a remote data center through the network or working with a file or a Graphical User Interface (GUI).
In all these circumstances, we must clean up the resource before the program comes to a halt whether it successfully ran or not. These actions (closing a file, GUI or disconnecting from network) are performed in the finally
clause to guarantee the execution.
Here is an example of file operations to illustrate this.
try: f = open("test.txt",encoding = 'utf-8') # perform file operations finally: f.close()
Šāda veida konstrukcija nodrošina faila aizvēršanu pat tad, ja programmas izpildes laikā rodas izņēmums.