Python Thử ngoại trừ - Python Xử lý ngoại lệ với các ví dụ

Hướng dẫn này giải thích về Xử lý ngoại lệ trong Python bằng cách sử dụng khối Thử ngoại trừ với sự trợ giúp của các ví dụ lập trình:

Hai loại lỗi có thể khiến chương trình Python dừng đột ngột, tức là Cú pháp Lỗi Ngoại lệ . Trong hướng dẫn này, chúng ta sẽ thảo luận về loại lỗi thứ hai (Ngoại lệ) trong một số chủ đề quan trọng.

Chúng ta sẽ thu được nhiều lợi ích từ việc xử lý các ngoại lệ trong ứng dụng của mình, chẳng hạn như:

  • Tạo ứng dụng mạnh mẽ.
  • Tạo mã rõ ràng và không có lỗi.

Thử ngoại lệ trong Python

Một tin vui là Python có một số lượng lớn các ngoại lệ được tích hợp sẵn để phát hiện lỗi trong mã của chúng ta. Ngoài ra, nó cho chúng tôi cơ hội tạo ngoại lệ tùy chỉnh khi không có ngoại lệ tích hợp nào phù hợp với nhu cầu của chúng tôi.

Ngoại lệ là gì

Vậy ngoại lệ trong Python là gì? Chà, nói một cách đơn giản, bất cứ khi nào trình thông dịch Python cố gắng thực thi mã không hợp lệ, nó sẽ đưa ra một ngoại lệ và trong trường hợp một ngoại lệ như vậy không được xử lý, nó sẽ phá vỡ luồng hướng dẫn bình thường của chương trình và in một dấu vết.

Hãy tạo một mã không hợp lệ và xem trình thông dịch Python sẽ phản hồi như thế nào.

Mở trình bao Python và chạy mã sau đây.

>>> 50/0

Đây là một trong số những lỗi phổ biến nhất trong lập trình. Đoạn mã trên cố gắng chia số 50 cho 0 (không). con trănbiến openFile trước khi nó được gán.

Một thủ thuật nhỏ ở đây là sử dụng trình xử lý ngoại lệ bên trong khối cuối cùng.

def readFile(file_path): try: openFile = open(file_path,'r') # Open a file as read-only print(openFile.readline()) # Read first line of file content except FileNotFoundError as ex: print(ex) finally: try: print("Cleaning...") openFile.close() except: # catches all exceptions pass # Ignore this error because we don't care. if __name__ == '__main__': filePath = './text.txt' readFile(filePath) 

Nếu khối thử của chúng tôi làm tăng FileNotFoundError, thì chúng tôi sẽ có đầu ra sau

Tăng ngoại lệ

Một tin tốt về ngoại lệ Python là chúng tôi có thể cố ý nuôi chúng. Các ngoại lệ được đưa ra bằng câu lệnh nâng cao .

Câu lệnh nâng cao có cú pháp sau:

raise [ExceptionName[(*args: Object)]]

Mở một thiết bị đầu cuối và đưa ra bất kỳ đối tượng ngoại lệ nào từ các Ngoại lệ dựng sẵn của Python. Ví dụ: nếu chúng tôi tăng ZeroDivisionError:

>>> raise ZeroDivisionError("Can't divide by zero")

Chúng tôi sẽ nhận được truy nguyên:

Vì vậy, tại sao việc đưa ra các ngoại lệ lại quan trọng?

  • Khi làm việc với các ngoại lệ tùy chỉnh.
  • Trong quá trình kiểm tra độ chính xác.

Các lớp ngoại lệ tùy chỉnh

Một ngoại lệ tùy chỉnh là một ngoại lệ mà bạn tạo để xử lý các lỗi dành riêng cho nhu cầu của bạn. Bí quyết là, chúng ta định nghĩa một lớp bắt nguồn từ đối tượng Ngoại lệ , sau đó chúng ta sử dụng câu lệnh nâng cao để nâng cao lớp ngoại lệ của mình.

Giả sử chúng ta muốn kiểm tra đầu vào của người dùng và đảm bảo rằng giá trị đầu vào không âm (kiểm tra độ chính xác). Tất nhiên, chúng ta có thể nêu ra lỗi ValueError ngoại lệ của Python nhưng chúng ta sẽ muốn tùy chỉnh lỗi bằng cách đặt cho nó một tên cụ thể và dễ hiểu như InputIsNegativeError . Nhưng ngoại lệ này không phải là Python tích hợpNgoại lệ.

Vì vậy, trước tiên, chúng ta tạo lớp cơ sở sẽ xuất phát từ Ngoại lệ.

class CustomError(Exception): "Base class exception for all exceptions of this module" pass 

Sau đó, chúng ta tạo lớp ngoại lệ sẽ kế thừa lớp cơ sở và sẽ xử lý lỗi cụ thể của chúng ta.

class InputIsNegativeError(CustomError): """Raised when User enters a negative value""" pass 

Hãy kiểm tra điều này

try: value = int(input()) if value  0: raise InputIsNegativeError # Raise exception if value is negative except InputIsNegativeError: # catch and handle exception print("Input value shouldn't be negative") 

Yêu cầu mã ở trên đối với đầu vào của người dùng và kiểm tra xem nó có âm không. Nếu đúng, nó sẽ làm tăng lỗi ngoại lệ tùy chỉnh InputIsNegativeError của chúng tôi. Lỗi này sau đó sẽ được bắt gặp trong câu lệnh ngoại trừ.

Dưới đây là mã hoàn chỉnh:

class CustomError(Exception): "Base class exception for all exceptions of this module" pass class InputIsNegativeError(CustomError): """Raised when User enters a negative value""" pass if __name__ == '__main__': try: value = int(input("Input a number: ")) if value  0: raise InputIsNegativeError # Raise exception if value is negative except InputIsNegativeError: # catch and handle exception print("Input value shouldn't be negative") 

Nếu giá trị đầu vào là một số âm như -1, thì chúng ta sẽ có kết quả:

Hãy xem tài liệu Python để biết thêm chi tiết về các ngoại lệ tùy chỉnh của Python.

Câu hỏi thường gặp

Hỏi #1) Python xử lý ngoại lệ như thế nào?

Trả lời: Python xử lý ngoại lệ bằng cách sử dụng câu lệnh thử ngoại trừ . Mã có thể đưa ra ngoại lệ được đặt và thực thi trong khối thử trong khi khối ngoại trừ giữ mã sẽ xử lý ngoại lệ nếu có phát sinh.

Hỏi #2) Điều gì gây ra ngoại lệ trong Python?

Trả lời: Bất cứ khi nào trình thông dịch Python gặp mã không hợp lệ, nó sẽ đưa ra một ngoại lệ, đó là cách riêng của Python để nói với chúng tôi rằng một cái gì đó bất ngờ đã xảy ra. Chúng ta cũng có thể cố tình nêu ra các ngoại lệ bằng cách sử dụng câu lệnh nêu ra .

Hỏi #3) Python xử lý nhiều ngoại lệ như thế nào?

Trả lời: Python xử lý nhiều ngoại lệsử dụng một khối except duy nhất hoặc nhiều khối except.

Đối với một khối duy nhất, các ngoại lệ được truyền dưới dạng một bộ: except (Exception1, Exception2,..,ExceptionN) và kiểm tra Python cho một trận đấu từ phải sang trái. Trong trường hợp này, hành động tương tự được thực hiện cho từng ngoại lệ.

Một cách khác để bắt tất cả ngoại lệ là bỏ tên của ngoại lệ sau từ khóa except.

except: # handle all exceptions here

Cách thứ hai là để sử dụng một khối ngoại trừ cho mỗi ngoại lệ:

except Exception1: # code to handle Exception1 goes here except Exception2: # code to handle Exception2 goes here except ExceptionN: # code to handle ExceptionN goes here 

Bằng cách này, bạn có thể thực hiện các hành động riêng biệt cho từng Ngoại lệ.

Hỏi #4) Tại sao việc xử lý Ngoại lệ lại quan trọng trong Python?

Trả lời: Lợi ích của việc xử lý ngoại lệ trong Python là chúng ta có thể tạo các ứng dụng mạnh mẽ, rõ ràng và không có lỗi. Chúng tôi không muốn mã sản xuất của mình bị lỗi do một số lỗi, vì vậy chúng tôi xử lý lỗi và duy trì hoạt động của ứng dụng.

Hỏi #5) Làm cách nào để bạn bỏ qua một ngoại lệ trong Python?

Trả lời: Để bỏ qua một ngoại lệ trong Python, hãy sử dụng từ khóa pass trong khối ngoại trừ. Giả sử chúng ta muốn bỏ qua ngoại lệ ValueError. Chúng tôi sẽ thực hiện theo cách này:

except ValueError: pass

Trừ khi bạn biết mình đang làm gì, nếu không thì việc bỏ qua các ngoại lệ là một phương pháp không tốt. Ít nhất, hãy thông báo cho người dùng về tất cả các lỗi có thể xảy ra.

Kết luận

Trong hướng dẫn này, chúng tôi đã đề cập đến: Ngoại lệ Python, Traceback; cách xử lý ngoại lệ với Try / Exception / Else / Final chặn, cách Tăng Ngoại lệ và cuối cùng là cách tạo Ngoại lệ tùy chỉnh của riêng chúng tôi.

Cảm ơn bạn đã đọc!

trình thông dịch coi đây là một thao tác không hợp lệ và gây ra Lỗi ZeroDivision, làm gián đoạn chương trình và in một truy nguyên.

Chúng ta có thể thấy rõ rằng ZeroDivisionError là ngoại lệ đã được nêu ra. Đó thực sự là cách riêng của Python để cho chúng ta biết rằng chia một số cho 0 là không hay. Mặc dù trong các ngôn ngữ khác như JavaScript, đây không phải là lỗi; và python nghiêm cấm hành vi này.

Ngoài ra, điều quan trọng cần biết là đây chỉ là một đối tượng ngoại lệ và Python có sẵn nhiều đối tượng như vậy. Hãy xem tài liệu chính thức này của Python để xem tất cả các Ngoại lệ tích hợp sẵn của Python.

Hiểu về Truy nguyên

Trước khi chúng ta bắt đầu xử lý các ngoại lệ, tôi nghĩ rằng việc hiểu chính xác điều gì sẽ xảy ra nếu có ngoại lệ sẽ giúp ích cho bạn không được xử lý và cách Python cố gắng hết sức để thông báo cho chúng tôi về lỗi của chúng tôi.

Bất cứ khi nào Python gặp lỗi, nó sẽ đưa ra một ngoại lệ. Nếu ngoại lệ này không được xử lý, thì nó sẽ tạo ra một số thông tin được gọi là Traceback. Vì vậy, truy nguyên này chứa thông tin gì?

Nó chứa:

  • Thông báo lỗi cho chúng tôi biết ngoại lệ nào đã được đưa ra và điều gì đã xảy ra trước ngoại lệ này được nâng lên.
  • Các số dòng khác nhau của mã gây ra lỗi này. Lỗi có thể do một chuỗi lệnh gọi hàm được gọi là ngăn lệnh gọi mà chúng ta sẽ thảo luận sau tại đây.

Mặc dù đó là lỗihơi khó hiểu, chúng tôi hứa rằng ví dụ tiếp theo sẽ giúp chúng ta hiểu rõ hơn.

Nhớ lại truy nguyên được in từ phép chia 50 cho 0 ở trên, chúng ta có thể thấy rằng truy nguyên chứa các thông tin sau:

  • Tệp “”: Điều này cho chúng tôi biết rằng mã này đã được chạy từ một thiết bị đầu cuối bảng điều khiển.
  • dòng 1: Điều này cho chúng tôi biết rằng đã xảy ra lỗi trong số dòng này.
  • Lỗi ZeroDivision: chia cho zero: Lỗi này cho chúng tôi biết ngoại lệ nào đã được đưa ra và nguyên nhân gây ra ngoại lệ đó.

Hãy thử một ví dụ khác và có thể xem ngăn xếp cuộc gọi trông như thế nào. Mở một trình chỉnh sửa, nhập mã bên dưới và lưu dưới dạng tracebackExp .py

def stack1(numb): # 1 div = 0 # 2 stack2(numb, div) # 3 def stack2(numb, div): # 5 compute = numb/div # 6 print(compute) # 7 if __name__ == '__main__': # 9 numb = 5 # 10 stack1(numb) # 11 

Mở một thiết bị đầu cuối trong thư mục chứa tệp này và chạy.

python tracebackExp.py

Bạn sẽ thấy truy nguyên sau:

Việc truy nguyên ở trên có vẻ khó hiểu nhưng thực tế không phải vậy. Pythonistas đã nghĩ ra cách tốt nhất để đọc truy nguyên, đó là từ từ dưới lên . Vì vậy, hãy tận dụng sự hiểu biết này để thử và hiểu những gì mà quá trình truy nguyên này mang lại.

  • Cuối cùng, chúng tôi nhận được ngoại lệ đã được đưa ra và lý do tại sao nó được đưa ra.
  • Di chuyển lên trên, chúng tôi nhận được tên tệp tracebackExp .py nơi xảy ra lỗi này, quá trình tính toán gây ra lỗi này compute = tê/div, hàm stack2 và dòng số liên kết 6 nơi thực hiện quá trình tính toán này .
  • Di chuyển lên trên, chúng tôi thấy rằng chức năng stack2 của chúng tôiđã được gọi trong hàm stack1 ở dòng số 3.
  • Di chuyển lên trên cùng, chúng ta thấy rằng hàm stack1 đã được gọi ở dòng số 11. module > cho chúng tôi biết rằng đó là tệp đang được thực thi.

Các ngoại lệ phổ biến của Python

Thư viện Python xác định rất nhiều ngoại lệ tích hợp sẵn. Bạn có thể kiểm tra Tài liệu Python hoặc gọi hàm tích hợp sẵn local () như sau:

>>> dir(locals()['__builtins__'])

Chúng tôi sẽ không cố gắng giải quyết tất cả các ngoại lệ này, nhưng chúng tôi sẽ xem một số ngoại lệ phổ biến mà bạn có thể sẽ gặp phải.

#1) TypeError

Xảy ra khi một thao tác hoặc chức năng được áp dụng cho một đối tượng thuộc loại không phù hợp.

Ví dụ 1

Xét chương trình dưới đây. Nó nhận một số bị chia và số chia, sau đó tính toán và in kết quả của phép chia số bị chia cho số chia.

def compute_division(): dividend = int(input("Enter the dividend: ")) # cast string to int divisor = input("Enter the divisor: ") # no casting # Compute division result = dividend/divisor # print result print("The result of {}/{} is: {}".format(dividend, divisor, result)) if __name__ == '__main__': result = compute_division() 

Chúng tôi yêu cầu giá trị của số bị chia và số chia từ người dùng, nhưng chúng tôi quên truyền chuỗi của số chia giá trị thành một số nguyên. Vì vậy, chúng ta kết thúc với kiểu của số bị chia là số nguyên( int ) và kiểu của số chia là chuỗi( str ). Sau đó, chúng tôi nhận được TypeError do toán tử chia (/) không hoạt động trên các chuỗi.

Bạn có thể quan tâm khi biết rằng không giống như Python, Javascript có Type Coercion về cơ bản chuyển đổi một trong các loại toán hạng thành một giá trị tương đương của loại toán hạng khác khi toán hạng làcác loại khác nhau.

#2) ValueError

Lỗi này xảy ra khi một thao tác hoặc hàm nhận được một đối số có loại phù hợp nhưng giá trị không phù hợp.

Ví dụ 2

Hãy xem xét chương trình của chúng tôi trong Ví dụ 1 ở trên.

Nếu người dùng nhập một giá trị chữ và số cho cổ tức như '3a', thì chương trình của chúng tôi sẽ tăng ngoại lệ ValueError. Điều này là do, mặc dù phương thức int() của Python nhận bất kỳ số hoặc chuỗi nào và trả về một đối tượng số nguyên, nhưng giá trị chuỗi không được chứa các chữ cái hoặc bất kỳ giá trị không phải số nào.

#3) Lỗi thuộc tính

Ngoại lệ này xuất hiện khi gán hoặc tham chiếu một thuộc tính không tồn tại.

Ví dụ 3

Hãy xem xét chương trình dưới. Nó nhận một số và tính căn bậc hai của nó bằng cách sử dụng mô-đun toán học Python

def get_fraction(value, idx): arr = [4,5,2,0] # a list of numbers idx_value = arr[idx] # if idx is > arr length, IndexError will be raised value/idx_value # if idx_value == 0, ZeroDivisionError will be raised if __name__ =='__main__': # set 'value' and 'idx' value = 54 idx = 3 # call function in a try-except statement. try: result = get_fraction(value, idx) print("Fraction is ", result) except (IndexError, ZeroDivisionError) as ex: print(ex) 

Khi người dùng nhập một số, chương trình của chúng tôi sẽ cố gắng sử dụng một hàm từ mô-đun toán học để tính căn bậc hai của nó nhưng chỉ ở đây, chúng tôi đã phạm sai lầm. Thay vì sqrt, chúng tôi đã nhập nhầm sqr không tồn tại trong mô-đun toán học.

Vì vậy, chúng tôi đã cố gắng tham chiếu một thuộc tính sqr không tồn tại và dẫn đến đến ngoại lệ AttributeError được nêu ra. Hầu hết chúng ta đều mắc loại sai lầm này rất nhiều. Vì vậy, bạn không đơn độc.

Xử lý ngoại lệ bằng cách dùng thử ngoại trừ

Là một lập trình viên, một điều mà hầu hết chúng ta sẽ dành thời gian là viết một mã mạnh mẽđàn hồi. Mã không bị hỏng do một số lỗi. Trong Python, chúng ta có thể đạt được điều này bằng cách đặt các câu lệnh của mình bên trong một câu lệnh try except .

Câu lệnh Python Try-Except

Câu lệnh thử ngoại trừ có cấu trúc như sau:

try: #your code goes here except """Specify exception type(s) here""": #handle exception here 

Hãy đặt mã trong tracebackExp .py bên trong câu lệnh thử ngoại trừ.

def stack1(numb): # 1 div = 0 # 2 stack2(numb, div) # 3 def stack2(numb, div): # 5 try: # 6 compute = numb/div # 7 print(compute) # 8 except ZeroDivisionError as zde: # 9 print(zde) # 10 if __name__ == '__main__': # 12 numb = 5 # 13 stack1(numb) # 14 print("program continuous") # 15 

Chạy mã này sẽ tạo ra kết quả

Đây là cách câu lệnh try-ngoại trừ hoạt động. Python thực thi mã trong khối thử dòng 7-8 . Nếu không tìm thấy mã không hợp lệ, thì mã trong khối ngoại trừ dòng 10 sẽ bị bỏ qua và quá trình thực thi sẽ tiếp tục.

Nhưng, nếu tìm thấy mã không hợp lệ, thì quá trình thực thi sẽ dừng ngay lập tức trong thử chặn và kiểm tra xem ngoại lệ được đưa ra có khớp với ngoại lệ mà chúng tôi đã cung cấp trong câu lệnh except dòng 9 hay không. Nếu khớp, thì khối ngoại trừ được thực thi và tiếp tục. Nếu không, chương trình sẽ bị gián đoạn.

Khối thử thường chứa mã có thể gây ra ngoại lệ trong khi khối ngoại trừ bắt và xử lý ngoại lệ.

Xử lý nhiều Ngoại lệ Với ngoại lệ

Chúng tôi có thể xử lý nhiều ngoại lệ với một “ngoại lệ” hoặc nhiều “ngoại lệ”. Tất cả phụ thuộc vào cách bạn muốn xử lý từng ngoại lệ.

#1) Xử lý nhiều ngoại lệ với một ngoại lệ duy nhất

try: #your code goes here except(Exception1[, Exception2[,...ExceptionN]]]): #handle exception here 

Phương pháp này được sử dụng khi chúng tôi nghi ngờ rằng mã của mình có thểđưa ra các ngoại lệ khác nhau và chúng tôi muốn thực hiện cùng một hành động trong từng trường hợp. Vì vậy, nếu trình thông dịch Python tìm thấy kết quả khớp, thì mã được viết trong khối except sẽ thực thi.

Hãy xem xét mã Python mẫu bên dưới

def get_fraction(value, idx): arr = [4,5,2,0] # a list of numbers idx_value = arr[idx] # if idx is > arr length, IndexError will be raised value/idx_value # if idx_value == 0, ZeroDivisionError will be raised if __name__ =='__main__': # set 'value' and 'idx' value = 54 idx = 3 # call function in a try-except statement. try: result = get_fraction(value, idx) print("Fraction is ", result) except (IndexError, ZeroDivisionError) as ex: print(ex) 

Chúng ta có hai mã các trường hợp ngoại lệ có thể được nêu ra ở đây, ZeroDivisionError IndexError . Nếu bất kỳ ngoại lệ nào trong số này được đưa ra, thì khối ngoại trừ sẽ được thực thi.

Trong đoạn mã trên, idx=3, vì vậy idx_ value trở thành 0 và value /idx_ value sẽ làm tăng ZeroDivisionError

#2) Xử lý nhiều ngoại lệ với nhiều ngoại lệ

try: #your code goes here except Exception1: #handle exception1 here except Exception2: #handle exception2 here except ExceptionN: #handle exceptionN here 

Nếu chúng tôi muốn xử lý mỗi ngoại lệ riêng biệt, thì đây là cách bạn có thể thực hiện.

Hãy xem xét mã Python mẫu bên dưới

def get_fraction(value, idx): arr = [4,5,2,0] # a list of numbers idx_value = arr[idx] # if idx is > arr length, IndexError will be raised value/idx_value # if idx_value == 0, ZeroDivisionError will be raised if __name__ =='__main__': # set 'value' and 'idx' value = 54 idx = 5 # call function in a try-excepts statement. try: result = get_fraction(value, idx) print("Fraction is ", result) except IndexError: print("idx of {} is out of range".format(idx)) except ZeroDivisionError: print("arr[{}] is 0. Hence, can't divide by zero".format(idx)) except Exception as ex: print(ex) print("Not sure what happened so not safe to continue, \ app will be interrupted") raise ex 

Chúng tôi nhận thấy ở đây rằng Ngoại lệ đã được sử dụng trong câu lệnh except cuối cùng . Điều này là do đối tượng ngoại lệ Exception khớp với bất kỳ ngoại lệ nào. Vì lý do này, nó phải luôn ở cuối cùng, vì Python sẽ ngừng kiểm tra các trình xử lý ngoại lệ khác khi một trình xử lý ngoại lệ phù hợp.

Trong đoạn mã trên, idx=5 , do đó arr[idx ] sẽ tăng IndexError idx lớn hơn độ dài của danh sách mảng

Ngoài ra, không chắc ứng dụng của bạn đưa ra ngoại lệ nào sẽ không bao giờ an toàn để tiếp tục thực thi. Đó là lý do tại sao chúng tôi có loại Ngoại lệ để bắt bất kỳ ngoại lệ không được dự đoán nào. Sau đó, chúng tôi thông báo chongười dùng và làm gián đoạn ứng dụng bằng cách đưa ra cùng một ngoại lệ.

Hãy thử Câu lệnh Khác

Đây là một tính năng tùy chọn của việc xử lý ngoại lệ và cho phép bạn thêm mã mà bạn muốn chạy khi không có lỗi xảy ra. Nếu xảy ra lỗi, khối other này sẽ không chạy.

Hãy xem xét mã Python mẫu bên dưới, mở trình chỉnh sửa của bạn và lưu mã dưới dạng elseTry.py

def fraction_of_one(divisor): value = 1/divisor # if divisor is zero, ZeroDivisionError will be raised return value if __name__ == '__main__': while True: try: # Get input from the user. # if input is not a valid argument for int(), ValueError will be raised divisor = int(input("Enter a divisor: ")) # call our function to compute the fraction value = fraction_of_one(divisor) except (ValueError, ZeroDivisionError): print("Input can't be zero and should be a valid literal for int(). Please, try again!") else: print("Value: ", value) break 

Chúng tôi nhận thông tin đầu vào từ người dùng và sử dụng thông tin đó để chia 1. Chúng tôi có thể có hai trường hợp ngoại lệ ở đây, thông tin đầu vào của người dùng không hợp lệ sẽ gây ra ValueError zero(0) sẽ gây ra Lỗi ZeroDivision . Câu lệnh except của chúng tôi xử lý các lỗi này.

Bây giờ, chúng tôi muốn in ra giá trị của value . Khối khác của chúng tôi đảm bảo rằng nó chỉ được in nếu khối thử của chúng tôi thực thi mà không có lỗi. Điều này rất quan trọng vì nếu xảy ra lỗi trong khối thử của chúng tôi, thì giá trị sẽ không được xác định. Vì vậy, việc truy cập nó sẽ phát sinh một lỗi khác.

Chạy mã ở trên bằng Python elseTry.py

Kết quả ở trên cho thấy rằng đối với đầu vào đầu tiên, chúng tôi đã nhập 0 và nhấn ENTER. Vì số chia của chúng tôi nhận được 0, 1/số chia tăng lên zeroDivisionError . Đầu vào thứ hai của chúng tôi là k không hợp lệ cho int (), do đó, ngoại lệ ValueError được đưa ra.

Nhưng đầu vào cuối cùng của chúng tôi là 9 hợp lệ và là kết quả, chúng tôi đã nhận được giá trị của “ value ” được in là 0.1111111111111111

Thử cuối cùngCâu lệnh

Đây cũng là một tính năng tùy chọn của xử lý ngoại lệ và sẽ luôn chạy bất kể điều gì xảy ra trong trình xử lý ngoại lệ.

Đó là:

  • Có xảy ra ngoại lệ hay không
  • Ngay cả khi 'return' được gọi trong các khối khác.
  • Ngay cả khi tập lệnh bị thoát trong các khối khác

Vì vậy, nếu chúng tôi có một mã mà chúng tôi muốn chạy trong mọi tình huống, thì khối cuối cùng là người của chúng tôi. Khối này chủ yếu được sử dụng để dọn dẹp như đóng tệp.

Hãy xem xét mã Python mẫu bên dưới

def readFile(file_path): try: openFile = open(file_path,'r') # Open a file as read-only print(openFile.readline()) # Read first line of file content except FileNotFoundError as ex: print(ex) finally: print("Cleaning...") openFile.close() if __name__ == '__main__': filePath = './text.txt' readFile(filePath) 

Mã này cố mở và đọc tệp text.txt trong thư mục hiện tại của nó. Nếu tệp tồn tại, thì chương trình của chúng ta sẽ in dòng đầu tiên của tệp, sau đó khối cuối cùng của chúng ta sẽ chạy và đóng tệp.

Giả sử chúng ta có một tệp có tên text.txt trong thư mục chứa tệp chương trình này là và chứa Hello. Nếu chúng tôi chạy chương trình, chúng tôi sẽ có đầu ra

Ví dụ này được chọn có chủ ý vì tôi muốn chúng tôi giải quyết một vấn đề nhỏ có thể xảy ra khi đóng tệp trong phần cuối cùng- chặn.

Nếu tệp không tồn tại, ngoại lệ FileNotFoundError sẽ được đưa ra và biến openFile sẽ không được xác định và sẽ không phải là một tệp sự vật. Do đó, cố gắng đóng nó trong khối cuối cùng sẽ tạo ra một ngoại lệ UnboundLocalError là một lớp con của NameError .

Về cơ bản, điều này nói rằng chúng tôi đang cố gắng tham chiếu các

Cuộn lên đầu trang