Python izņēmumu apstrāde Izmantojot try, izņemot un visbeidzot paziņojumu

Š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, Akas izsauc funkciju B, kas savukārt izsauc funkciju C. Ja izņēmums notiek funkcijā, Cbet netiek apstrādāts C, izņēmums pāriet uz Bun 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 trypaziņojumu.

Kritiskā darbība, kas var izraisīt izņēmumu, tiek ievietota tryklauzulas iekšpusē . Kods, kas apstrādā izņēmumus, ir ierakstīts exceptklauzulā.

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 trybloka iekšpusē .

Ja nenotiek izņēmums, exceptbloks tiek izlaists un normāla plūsma turpinās (pēdējai vērtībai). Bet, ja rodas kāds izņēmums, to uztver exceptbloks (pirmā un otrā vērtība).

Šeit mēs izdrukājam izņēmuma nosaukumu, izmantojot exc_info()funkciju sysmoduļa iekšpusē . Mēs varam redzēt, ka acēloņi ValueErrorun 0cēloņi ZeroDivisionError.

Tā kā katrs Python izņēmums tiek mantots no bāzes Exceptionklases, 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 exceptklauzulā 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 exceptjāiekļauj klauzulā.

tryKlauzula var būt jebkurš skaits exceptklauzulas, 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 raiseatslē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 trydarbojās bez kļūdām. Šādos gadījumos elsear trypaziņ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, ZeroDivisionErrorjo koda bloks iekšpusē elsenetiek 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.

Interesanti raksti...