ਪਾਇਥਨ ਨੂੰ ਛੱਡ ਕੇ ਕੋਸ਼ਿਸ਼ ਕਰੋ - ਉਦਾਹਰਨਾਂ ਦੇ ਨਾਲ ਪਾਇਥਨ ਹੈਂਡਲਿੰਗ ਅਪਵਾਦ

ਇਹ ਟਿਊਟੋਰਿਅਲ ਪ੍ਰੋਗ੍ਰਾਮਿੰਗ ਉਦਾਹਰਨਾਂ ਦੀ ਮਦਦ ਨਾਲ Try Except ਬਲਾਕ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ ਪਾਇਥਨ ਵਿੱਚ ਅਪਵਾਦ ਹੈਂਡਲਿੰਗ ਦੀ ਵਿਆਖਿਆ ਕਰਦਾ ਹੈ:

ਦੋ ਗਲਤੀ ਕਿਸਮਾਂ ਇੱਕ ਪਾਈਥਨ ਪ੍ਰੋਗਰਾਮ ਨੂੰ ਅਚਾਨਕ ਬੰਦ ਕਰਨ ਦਾ ਕਾਰਨ ਬਣ ਸਕਦੀਆਂ ਹਨ ਜਿਵੇਂ ਕਿ ਸਿੰਟੈਕਸ ਗਲਤੀਆਂ , ਅਤੇ ਅਪਵਾਦ । ਇਸ ਟਿਊਟੋਰਿਅਲ ਵਿੱਚ, ਅਸੀਂ ਕਈ ਮਹੱਤਵਪੂਰਨ ਵਿਸ਼ਿਆਂ ਦੇ ਅਧੀਨ ਦੂਜੀ ਗਲਤੀ ਦੀ ਕਿਸਮ (ਅਪਵਾਦ) ਬਾਰੇ ਚਰਚਾ ਕਰਾਂਗੇ।

ਸਾਨੂੰ ਸਾਡੀ ਐਪਲੀਕੇਸ਼ਨ ਵਿੱਚ ਅਪਵਾਦਾਂ ਨੂੰ ਸੰਭਾਲਣ ਨਾਲ ਬਹੁਤ ਫਾਇਦਾ ਹੋਵੇਗਾ ਜਿਵੇਂ ਕਿ:

  • ਇੱਕ ਮਜਬੂਤ ਐਪਲੀਕੇਸ਼ਨ ਬਣਾਉਣਾ।
  • ਇੱਕ ਸਾਫ਼ ਅਤੇ ਗਲਤੀ ਰਹਿਤ ਕੋਡ ਬਣਾਉਣਾ।

ਪਾਈਥਨ ਨੂੰ ਛੱਡ ਕੇ ਕੋਸ਼ਿਸ਼ ਕਰੋ

ਇੱਕ ਚੰਗੀ ਖ਼ਬਰ ਇਹ ਹੈ ਕਿ ਪਾਈਥਨ ਵਿੱਚ ਸਾਡੇ ਕੋਡ ਵਿੱਚ ਤਰੁੱਟੀਆਂ ਨੂੰ ਫੜਨ ਲਈ ਬਿਲਟ-ਇਨ ਅਪਵਾਦਾਂ ਦੀ ਇੱਕ ਚੰਗੀ ਸੰਖਿਆ ਹੈ। ਨਾਲ ਹੀ, ਇਹ ਸਾਨੂੰ ਕਸਟਮ ਅਪਵਾਦ ਬਣਾਉਣ ਦਾ ਮੌਕਾ ਦਿੰਦਾ ਹੈ ਜਦੋਂ ਕੋਈ ਵੀ ਬਿਲਟ-ਇਨ ਅਪਵਾਦ ਸਾਡੀਆਂ ਜ਼ਰੂਰਤਾਂ ਨੂੰ ਪੂਰਾ ਨਹੀਂ ਕਰਦਾ।

ਅਪਵਾਦ ਕੀ ਹੈ

ਤਾਂ ਪਾਈਥਨ ਵਿੱਚ ਇੱਕ ਅਪਵਾਦ ਕੀ ਹੈ? ਖੈਰ, ਸਧਾਰਨ ਸ਼ਬਦਾਂ ਵਿੱਚ, ਜਦੋਂ ਵੀ ਪਾਈਥਨ ਦੁਭਾਸ਼ੀਏ ਅਵੈਧ ਕੋਡ ਨੂੰ ਚਲਾਉਣ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰਦਾ ਹੈ, ਇਹ ਇੱਕ ਅਪਵਾਦ ਪੈਦਾ ਕਰਦਾ ਹੈ, ਅਤੇ ਉਹਨਾਂ ਮਾਮਲਿਆਂ ਵਿੱਚ ਜਿੱਥੇ ਅਜਿਹੇ ਅਪਵਾਦ ਨੂੰ ਸੰਭਾਲਿਆ ਨਹੀਂ ਜਾਂਦਾ, ਇਹ ਪ੍ਰੋਗਰਾਮ ਦੇ ਨਿਰਦੇਸ਼ਾਂ ਦੇ ਆਮ ਪ੍ਰਵਾਹ ਵਿੱਚ ਵਿਘਨ ਪਾਉਂਦਾ ਹੈ ਅਤੇ ਇੱਕ ਟਰੇਸਬੈਕ ਪ੍ਰਿੰਟ ਕਰਦਾ ਹੈ।

ਆਓ ਇੱਕ ਅਵੈਧ ਕੋਡ ਬਣਾਉ ਅਤੇ ਵੇਖੀਏ ਕਿ Python ਇੰਟਰਪ੍ਰੇਟਰ ਕਿਵੇਂ ਜਵਾਬ ਦੇਵੇਗਾ।

ਇੱਕ Python ਸ਼ੈੱਲ ਖੋਲ੍ਹੋ ਅਤੇ ਹੇਠਾਂ ਦਿੱਤਾ ਕੋਡ ਚਲਾਓ।

>>> 50/0

ਇਹ ਇਹਨਾਂ ਵਿੱਚੋਂ ਇੱਕ ਹੈ ਪ੍ਰੋਗਰਾਮਿੰਗ ਵਿੱਚ ਸਭ ਤੋਂ ਆਮ ਗਲਤੀਆਂ. ਉਪਰੋਕਤ ਕੋਡ ਨੰਬਰ 50 ਨੂੰ 0 (ਜ਼ੀਰੋ) ਨਾਲ ਵੰਡਣ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰਦਾ ਹੈ। ਪਾਈਥਨਵੇਰੀਏਬਲ openFile ਇਸ ਨੂੰ ਨਿਰਧਾਰਤ ਕੀਤੇ ਜਾਣ ਤੋਂ ਪਹਿਲਾਂ।

ਇੱਥੇ ਇੱਕ ਛੋਟੀ ਚਾਲ ਹੈ ਅੰਤਮ-ਬਲਾਕ ਦੇ ਅੰਦਰ ਅਪਵਾਦ ਹੈਂਡਲਰ ਦੀ ਵਰਤੋਂ ਕਰਨਾ।

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) 

ਜੇਕਰ ਸਾਡਾ ਟਰਾਈ-ਬਲਾਕ FileNotFoundError ਨੂੰ ਉਭਾਰਦਾ ਹੈ, ਤਾਂ ਸਾਡੇ ਕੋਲ ਹੇਠਾਂ ਦਿੱਤੀ ਆਉਟਪੁੱਟ ਹੋਵੇਗੀ

Raise Exception

Python ਅਪਵਾਦਾਂ ਬਾਰੇ ਇੱਕ ਚੰਗੀ ਖ਼ਬਰ ਇਹ ਹੈ ਕਿ ਅਸੀਂ ਜਾਣਬੁੱਝ ਕੇ ਕਰ ਸਕਦੇ ਹਾਂ ਉਹਨਾਂ ਨੂੰ ਉਠਾਓ. ਅਪਵਾਦਾਂ ਨੂੰ ਰਾਈਜ਼ ਸਟੇਟਮੈਂਟ ਨਾਲ ਉਠਾਇਆ ਜਾਂਦਾ ਹੈ।

ਰਾਈਜ਼ ਸਟੇਟਮੈਂਟ ਵਿੱਚ ਹੇਠ ਲਿਖੇ ਸੰਟੈਕਸ ਹੁੰਦੇ ਹਨ:

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

ਟਰਮੀਨਲ ਖੋਲ੍ਹੋ ਅਤੇ ਕਿਸੇ ਵੀ ਅਪਵਾਦ ਆਬਜੈਕਟ ਨੂੰ ਉਭਾਰੋ ਪਾਈਥਨ ਇਨ-ਬਿਲਟ ਅਪਵਾਦ। ਉਦਾਹਰਨ ਲਈ, ਜੇਕਰ ਅਸੀਂ ZeroDivisionError:

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

ਸਾਨੂੰ ਟਰੇਸਬੈਕ ਮਿਲੇਗਾ:

ਇਸ ਲਈ, ਅਪਵਾਦਾਂ ਨੂੰ ਵਧਾਉਣਾ ਮਹੱਤਵਪੂਰਨ ਕਿਉਂ ਹੈ?

  • ਕਸਟਮ ਅਪਵਾਦਾਂ ਨਾਲ ਕੰਮ ਕਰਦੇ ਸਮੇਂ।
  • ਸੈਨੀਟੀ ਜਾਂਚਾਂ ਦੌਰਾਨ।

ਕਸਟਮ ਅਪਵਾਦ ਕਲਾਸਾਂ

ਇੱਕ ਕਸਟਮ ਅਪਵਾਦ ਉਹ ਹੁੰਦਾ ਹੈ ਜੋ ਤੁਸੀਂ ਉਹਨਾਂ ਤਰੁੱਟੀਆਂ ਨੂੰ ਸੰਭਾਲਣ ਲਈ ਬਣਾਉਂਦੇ ਹੋ ਜੋ ਤੁਹਾਡੀ ਲੋੜ ਲਈ ਖਾਸ ਹਨ। ਚਾਲ ਇਹ ਹੈ, ਅਸੀਂ ਇੱਕ ਕਲਾਸ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦੇ ਹਾਂ ਜੋ ਆਬਜੈਕਟ ਅਪਵਾਦ ਤੋਂ ਲਿਆ ਜਾਂਦਾ ਹੈ, ਫਿਰ ਅਸੀਂ ਆਪਣੀ ਅਪਵਾਦ ਕਲਾਸ ਨੂੰ ਵਧਾਉਣ ਲਈ raise ਸਟੇਟਮੈਂਟ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹਾਂ।

ਮੰਨ ਲਓ ਕਿ ਅਸੀਂ ਉਪਭੋਗਤਾ ਇੰਪੁੱਟ ਦੀ ਜਾਂਚ ਕਰਨਾ ਚਾਹੁੰਦੇ ਹਾਂ ਅਤੇ ਯਕੀਨੀ ਬਣਾਉਣਾ ਚਾਹੁੰਦੇ ਹਾਂ। ਇੰਪੁੱਟ ਮੁੱਲ ਨਕਾਰਾਤਮਕ ਨਹੀਂ ਹੈ (ਸੈਨੀਟੀ ਜਾਂਚ)। ਬੇਸ਼ੱਕ, ਅਸੀਂ ਪਾਈਥਨ ਅਪਵਾਦ ValueError ਨੂੰ ਵਧਾ ਸਕਦੇ ਹਾਂ ਪਰ ਅਸੀਂ ਇਸ ਨੂੰ ਇੱਕ ਖਾਸ ਅਤੇ ਸਵੈ-ਵਿਆਖਿਆਤਮਕ ਨਾਮ ਦੇ ਕੇ ਇਸ ਨੂੰ ਅਨੁਕੂਲਿਤ ਕਰਨਾ ਚਾਹਾਂਗੇ ਜਿਵੇਂ ਕਿ InputIsNegativeError । ਪਰ ਇਹ ਅਪਵਾਦ ਇੱਕ ਪਾਈਥਨ ਇਨ-ਬਿਲਟ ਨਹੀਂ ਹੈਅਪਵਾਦ।

ਇਸ ਲਈ ਪਹਿਲਾਂ, ਅਸੀਂ ਆਪਣੀ ਬੇਸ ਕਲਾਸ ਬਣਾਉਂਦੇ ਹਾਂ ਜੋ ਅਪਵਾਦ ਤੋਂ ਪ੍ਰਾਪਤ ਹੋਵੇਗੀ।

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

ਫਿਰ ਅਸੀਂ ਆਪਣੀ ਅਪਵਾਦ ਕਲਾਸ ਬਣਾਉਂਦੇ ਹਾਂ ਜੋ ਬੇਸ ਕਲਾਸ ਨੂੰ ਪ੍ਰਾਪਤ ਕਰੇਗੀ ਅਤੇ ਸਾਡੀ ਖਾਸ ਗਲਤੀ ਨੂੰ ਸੰਭਾਲੇਗੀ।

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

ਆਉ ਇਸਦੀ ਜਾਂਚ ਕਰੀਏ

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") 

ਉਪਯੋਗਕਰਤਾ ਇੰਪੁੱਟ ਲਈ ਉਪਰੋਕਤ ਕੋਡ ਬੇਨਤੀ, ਅਤੇ ਜਾਂਚ ਕਰੋ ਕਿ ਕੀ ਇਹ ਨਕਾਰਾਤਮਕ ਹੈ। ਜੇਕਰ ਸਹੀ ਹੈ, ਤਾਂ ਇਹ ਸਾਡੀ ਕਸਟਮ ਅਪਵਾਦ InputIsNegativeError ਨੂੰ ਵਧਾਉਂਦਾ ਹੈ ਜੋ ਬਾਅਦ ਵਿੱਚ ਸਿਵਾਏ-ਸਟੇਟਮੈਂਟ ਵਿੱਚ ਫੜਿਆ ਜਾਂਦਾ ਹੈ।

ਹੇਠਾਂ ਪੂਰਾ ਕੋਡ ਹੈ:

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") 

ਜੇ ਇਨਪੁਟ ਮੁੱਲ -1 ਵਰਗਾ ਇੱਕ ਨੈਗੇਟਿਵ ਨੰਬਰ ਹੈ, ਤਾਂ ਸਾਡੇ ਕੋਲ ਆਉਟਪੁੱਟ ਹੋਵੇਗਾ:

ਪਾਈਥਨ ਕਸਟਮ ਅਪਵਾਦਾਂ ਬਾਰੇ ਹੋਰ ਵੇਰਵਿਆਂ ਲਈ ਪਾਈਥਨ ਡੌਕ ਦੀ ਜਾਂਚ ਕਰੋ।

ਅਕਸਰ ਪੁੱਛੇ ਜਾਂਦੇ ਸਵਾਲ

ਪ੍ਰ #1) ਪਾਈਥਨ ਇੱਕ ਅਪਵਾਦ ਨੂੰ ਕਿਵੇਂ ਸੰਭਾਲਦਾ ਹੈ?

ਜਵਾਬ: ਪਾਈਥਨ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਅਪਵਾਦਾਂ ਨੂੰ ਸੰਭਾਲਦਾ ਹੈ ਕੋਸ਼ਿਸ਼-ਸਿਵਾਏ ਬਿਆਨ । ਕੋਡ ਜੋ ਇੱਕ ਅਪਵਾਦ ਪੈਦਾ ਕਰ ਸਕਦਾ ਹੈ, ਨੂੰ ਟ੍ਰਾਈ ਬਲਾਕ ਵਿੱਚ ਰੱਖਿਆ ਅਤੇ ਚਲਾਇਆ ਜਾਂਦਾ ਹੈ ਜਦੋਂ ਕਿ ਬਲਾਕ ਨੂੰ ਛੱਡ ਕੇ ਕੋਡ ਰੱਖਦਾ ਹੈ ਜੋ ਅਪਵਾਦਾਂ ਨੂੰ ਹੈਂਡਲ ਕਰੇਗਾ ਜੇਕਰ ਕੋਈ ਪੈਦਾ ਹੁੰਦਾ ਹੈ।

ਸਵਾਲ #2) ਪਾਈਥਨ ਵਿੱਚ ਇੱਕ ਅਪਵਾਦ ਕੀ ਹੈ?

ਜਵਾਬ: ਜਦੋਂ ਵੀ ਪਾਈਥਨ ਇੰਟਰਪ੍ਰੇਟਰ ਇੱਕ ਅਵੈਧ ਕੋਡ ਦਾ ਸਾਹਮਣਾ ਕਰਦਾ ਹੈ, ਤਾਂ ਇਹ ਇੱਕ ਅਪਵਾਦ ਪੈਦਾ ਕਰਦਾ ਹੈ, ਜੋ ਕਿ ਪਾਈਥਨ ਦਾ ਆਪਣਾ ਤਰੀਕਾ ਹੈ। ਸਾਨੂੰ ਇਹ ਦੱਸਣ ਲਈ ਕਿ ਕੁਝ ਅਚਾਨਕ ਵਾਪਰਿਆ ਹੈ। ਅਸੀਂ ਜਾਣਬੁੱਝ ਕੇ ਰਾਈਜ਼ ਸਟੇਟਮੈਂਟ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਅਪਵਾਦਾਂ ਨੂੰ ਵਧਾ ਸਕਦੇ ਹਾਂ।

ਪ੍ਰ #3) ਪਾਈਥਨ ਕਈ ਅਪਵਾਦਾਂ ਨੂੰ ਕਿਵੇਂ ਸੰਭਾਲਦਾ ਹੈ?

ਜਵਾਬ: ਪਾਈਥਨ ਕਈ ਅਪਵਾਦਾਂ ਨੂੰ ਸੰਭਾਲਦਾ ਹੈਬਲਾਕ ਨੂੰ ਛੱਡ ਕੇ ਜਾਂ ਬਲਾਕਾਂ ਨੂੰ ਛੱਡ ਕੇ ਮਲਟੀਪਲ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ।

ਇੱਕ ਸਿੰਗਲ ਬਲਾਕ ਲਈ, ਅਪਵਾਦਾਂ ਨੂੰ ਟੂਪਲ ਵਜੋਂ ਪਾਸ ਕੀਤਾ ਜਾਂਦਾ ਹੈ: ਸਿਵਾਏ (ਅਪਵਾਦ1, ਅਪਵਾਦ2,..,ਅਪਵਾਦN) ਅਤੇ ਪਾਈਥਨ ਜਾਂਚ ਸੱਜੇ ਤੋਂ ਖੱਬੇ ਮੈਚ ਲਈ। ਇਸ ਸਥਿਤੀ ਵਿੱਚ, ਹਰੇਕ ਅਪਵਾਦ ਲਈ ਇੱਕੋ ਜਿਹੀ ਕਾਰਵਾਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ।

ਸਾਰੇ ਅਪਵਾਦਾਂ ਨੂੰ ਫੜਨ ਦਾ ਇੱਕ ਹੋਰ ਤਰੀਕਾ ਹੈ ਅਪਵਾਦ ਦੇ ਨਾਮ ਨੂੰ ਛੱਡਣ ਵਾਲੇ ਕੀਵਰਡ ਤੋਂ ਬਾਅਦ ਛੱਡਣਾ।

except: # handle all exceptions here

ਦੂਜਾ ਤਰੀਕਾ ਹੈ। ਹਰੇਕ ਅਪਵਾਦ ਲਈ ਇੱਕ ਸਿਵਾਏ ਬਲਾਕ ਦੀ ਵਰਤੋਂ ਕਰਨ ਲਈ:

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

ਇਸ ਤਰ੍ਹਾਂ, ਤੁਸੀਂ ਹਰੇਕ ਅਪਵਾਦ ਲਈ ਵੱਖਰੀਆਂ ਕਾਰਵਾਈਆਂ ਕਰ ਸਕਦੇ ਹੋ।

ਪ੍ਰ #4) ਪਾਇਥਨ ਵਿੱਚ ਅਪਵਾਦ ਹੈਂਡਲਿੰਗ ਮਹੱਤਵਪੂਰਨ ਕਿਉਂ ਹੈ?

ਜਵਾਬ: ਪਾਈਥਨ ਵਿੱਚ ਅਪਵਾਦਾਂ ਨੂੰ ਸੰਭਾਲਣ ਦਾ ਫਾਇਦਾ ਇਹ ਹੈ ਕਿ ਅਸੀਂ ਮਜ਼ਬੂਤ, ਸਾਫ਼ ਅਤੇ ਗਲਤੀ-ਮੁਕਤ ਐਪਲੀਕੇਸ਼ਨ ਬਣਾ ਸਕਦੇ ਹਾਂ। ਅਸੀਂ ਨਹੀਂ ਚਾਹਾਂਗੇ ਕਿ ਸਾਡਾ ਉਤਪਾਦਨ ਕੋਡ ਕੁਝ ਤਰੁੱਟੀਆਂ ਦੇ ਕਾਰਨ ਕ੍ਰੈਸ਼ ਹੋ ਜਾਵੇ, ਇਸਲਈ ਅਸੀਂ ਤਰੁੱਟੀਆਂ ਨੂੰ ਸੰਭਾਲਦੇ ਹਾਂ ਅਤੇ ਆਪਣੀ ਐਪਲੀਕੇਸ਼ਨ ਨੂੰ ਚਾਲੂ ਰੱਖਦੇ ਹਾਂ।

ਪ੍ਰ #5) ਤੁਸੀਂ ਪਾਈਥਨ ਵਿੱਚ ਇੱਕ ਅਪਵਾਦ ਨੂੰ ਕਿਵੇਂ ਅਣਡਿੱਠ ਕਰਦੇ ਹੋ?

ਜਵਾਬ: ਪਾਈਥਨ ਵਿੱਚ ਇੱਕ ਅਪਵਾਦ ਨੂੰ ਅਣਡਿੱਠ ਕਰਨ ਲਈ, ਸਿਵਾਏਟ ਬਲਾਕ ਵਿੱਚ ਪਾਸ ਕੀਵਰਡ ਦੀ ਵਰਤੋਂ ਕਰੋ। ਮੰਨ ਲਓ ਅਸੀਂ ValueError ਅਪਵਾਦ ਨੂੰ ਨਜ਼ਰਅੰਦਾਜ਼ ਕਰਨਾ ਚਾਹੁੰਦੇ ਹਾਂ। ਅਸੀਂ ਇਸਨੂੰ ਇਸ ਤਰੀਕੇ ਨਾਲ ਕਰਾਂਗੇ:

except ValueError: pass

ਜਦੋਂ ਤੱਕ ਤੁਸੀਂ ਨਹੀਂ ਜਾਣਦੇ ਹੋ ਕਿ ਤੁਸੀਂ ਕੀ ਕਰ ਰਹੇ ਹੋ, ਅਪਵਾਦਾਂ ਨੂੰ ਨਜ਼ਰਅੰਦਾਜ਼ ਕਰਨਾ ਬੁਰਾ ਅਭਿਆਸ ਹੈ। ਘੱਟੋ-ਘੱਟ, ਸਾਰੀਆਂ ਸੰਭਾਵੀ ਗਲਤੀਆਂ ਬਾਰੇ ਉਪਭੋਗਤਾ ਨੂੰ ਸੂਚਿਤ ਕਰੋ।

ਸਿੱਟਾ

ਇਸ ਟਿਊਟੋਰਿਅਲ ਵਿੱਚ, ਅਸੀਂ ਕਵਰ ਕੀਤਾ ਹੈ: ਪਾਈਥਨ ਅਪਵਾਦ, ਟਰੇਸਬੈਕ; ਕੋਸ਼ਿਸ਼ ਕਰੋ / ਸਿਵਾਏ / ਹੋਰ / ਅੰਤ ਵਿੱਚ ਨਾਲ ਅਪਵਾਦਾਂ ਨੂੰ ਕਿਵੇਂ ਸੰਭਾਲਣਾ ਹੈਬਲਾਕ, ਕਿਵੇਂ ਉਭਾਰੀਏ ਅਪਵਾਦ, ਅਤੇ ਅੰਤ ਵਿੱਚ ਸਾਡੇ ਆਪਣੇ ਕਸਟਮ ਅਪਵਾਦ ਕਿਵੇਂ ਬਣਾਏ।

ਪੜ੍ਹਨ ਲਈ ਧੰਨਵਾਦ!

ਦੁਭਾਸ਼ੀਏ ਇਸਨੂੰ ਇੱਕ ਅਵੈਧ ਕਾਰਵਾਈ ਦੇ ਰੂਪ ਵਿੱਚ ਵੇਖਦਾ ਹੈ ਅਤੇ ਇੱਕ ਜ਼ੀਰੋ ਡਿਵੀਜ਼ਨ ਐਰਰਉਠਾਉਂਦਾ ਹੈ, ਪ੍ਰੋਗਰਾਮ ਵਿੱਚ ਵਿਘਨ ਪਾਉਂਦਾ ਹੈ, ਅਤੇ ਇੱਕ ਟਰੇਸਬੈਕ ਪ੍ਰਿੰਟ ਕਰਦਾ ਹੈ।

ਅਸੀਂ ਸਪਸ਼ਟ ਤੌਰ 'ਤੇ ਦੇਖ ਸਕਦੇ ਹਾਂ ਕਿ ZeroDivisionError ਉਹ ਅਪਵਾਦ ਹੈ ਜੋ ਉਠਾਇਆ ਗਿਆ ਸੀ। ਇਹ ਅਸਲ ਵਿੱਚ ਪਾਈਥਨ ਦਾ ਸਾਨੂੰ ਇਹ ਦੱਸਣ ਦਾ ਆਪਣਾ ਤਰੀਕਾ ਹੈ ਕਿ ਕਿਸੇ ਸੰਖਿਆ ਨੂੰ ਜ਼ੀਰੋ ਨਾਲ ਵੰਡਣਾ ਵਧੀਆ ਨਹੀਂ ਹੈ। ਹਾਲਾਂਕਿ JavaScript ਵਰਗੀਆਂ ਹੋਰ ਭਾਸ਼ਾਵਾਂ ਵਿੱਚ, ਇਹ ਇੱਕ ਗਲਤੀ ਨਹੀਂ ਹੈ; ਅਤੇ python ਇਸ ਅਭਿਆਸ ਨੂੰ ਸਖਤੀ ਨਾਲ ਮਨ੍ਹਾ ਕਰਦਾ ਹੈ।

ਨਾਲ ਹੀ, ਇਹ ਜਾਣਨਾ ਵੀ ਮਹੱਤਵਪੂਰਨ ਹੈ ਕਿ ਇਹ ਸਿਰਫ਼ ਇੱਕ ਅਪਵਾਦ ਵਸਤੂ ਹੈ ਅਤੇ ਪਾਈਥਨ ਵਿੱਚ ਅਜਿਹੀਆਂ ਬਹੁਤ ਸਾਰੀਆਂ ਵਸਤੂਆਂ ਇਨ-ਬਿਲਟ ਹਨ। ਸਾਰੇ Python ਬਿਲਟ-ਇਨ ਅਪਵਾਦਾਂ ਨੂੰ ਦੇਖਣ ਲਈ ਇਸ Python ਅਧਿਕਾਰਤ ਦਸਤਾਵੇਜ਼ਾਂ ਨੂੰ ਦੇਖੋ।

ਟਰੇਸਬੈਕ ਨੂੰ ਸਮਝਣਾ

ਇਸ ਤੋਂ ਪਹਿਲਾਂ ਕਿ ਅਸੀਂ ਅਪਵਾਦਾਂ ਨੂੰ ਸੰਭਾਲਦੇ ਹਾਂ, ਮੈਨੂੰ ਲੱਗਦਾ ਹੈ ਕਿ ਇਹ ਸਮਝਣ ਵਿੱਚ ਮਦਦ ਕਰੇਗਾ ਕਿ ਜੇਕਰ ਅਪਵਾਦ ਹਨ ਤਾਂ ਅਸਲ ਵਿੱਚ ਕੀ ਹੋਵੇਗਾ ਨੂੰ ਸੰਭਾਲਿਆ ਨਹੀਂ ਜਾਂਦਾ ਹੈ ਅਤੇ ਪਾਈਥਨ ਸਾਡੀ ਗਲਤੀ ਬਾਰੇ ਸਾਨੂੰ ਸੂਚਿਤ ਕਰਨ ਲਈ ਸਭ ਤੋਂ ਵਧੀਆ ਕਿਵੇਂ ਕਰਦਾ ਹੈ।

ਜਦੋਂ ਵੀ ਪਾਈਥਨ ਨੂੰ ਕੋਈ ਗਲਤੀ ਆਉਂਦੀ ਹੈ, ਇਹ ਇੱਕ ਅਪਵਾਦ ਪੈਦਾ ਕਰਦਾ ਹੈ। ਜੇਕਰ ਇਸ ਅਪਵਾਦ ਨੂੰ ਸੰਭਾਲਿਆ ਨਹੀਂ ਜਾਂਦਾ ਹੈ, ਤਾਂ ਇਹ ਟਰੇਸਬੈਕ ਨਾਮਕ ਕੁਝ ਜਾਣਕਾਰੀ ਪੈਦਾ ਕਰਦਾ ਹੈ। ਤਾਂ, ਇਸ ਟਰੇਸਬੈਕ ਵਿੱਚ ਕਿਹੜੀ ਜਾਣਕਾਰੀ ਸ਼ਾਮਲ ਹੈ?

ਇਸ ਵਿੱਚ ਸ਼ਾਮਲ ਹੈ:

  • ਗਲਤੀ ਸੁਨੇਹਾ ਜੋ ਸਾਨੂੰ ਦੱਸਦਾ ਹੈ ਕਿ ਕਿਹੜਾ ਅਪਵਾਦ ਉਠਾਇਆ ਗਿਆ ਸੀ ਅਤੇ ਇਸ ਅਪਵਾਦ ਤੋਂ ਪਹਿਲਾਂ ਕੀ ਹੋਇਆ ਸੀ ਉਠਾਇਆ ਗਿਆ।
  • ਕੋਡ ਦੇ ਵੱਖ-ਵੱਖ ਲਾਈਨ ਨੰਬਰ ਜੋ ਇਸ ਗਲਤੀ ਦਾ ਕਾਰਨ ਬਣਦੇ ਹਨ। ਕਾਲ ਸਟੈਕ ਕਹਿੰਦੇ ਫੰਕਸ਼ਨ ਕਾਲਾਂ ਦੇ ਕ੍ਰਮ ਦੇ ਕਾਰਨ ਇੱਕ ਗਲਤੀ ਹੋ ਸਕਦੀ ਹੈ ਜਿਸਦੀ ਅਸੀਂ ਇੱਥੇ ਬਾਅਦ ਵਿੱਚ ਚਰਚਾ ਕਰਾਂਗੇ।

ਹਾਲਾਂਕਿ ਇਹ ਇੱਕ ਹੈਥੋੜਾ ਉਲਝਣ ਵਾਲਾ, ਅਸੀਂ ਵਾਅਦਾ ਕਰਦੇ ਹਾਂ ਕਿ ਅਗਲੀ ਉਦਾਹਰਣ ਸਾਡੀ ਸਮਝ ਵਿੱਚ ਹੋਰ ਰੋਸ਼ਨੀ ਲਿਆਵੇਗੀ।

ਉੱਪਰ 50 ਦੁਆਰਾ 0 ਨੂੰ ਵੰਡਣ ਤੋਂ ਛਾਪੇ ਗਏ ਟਰੇਸਬੈਕ ਨੂੰ ਯਾਦ ਕਰੋ, ਅਸੀਂ ਦੇਖ ਸਕਦੇ ਹਾਂ ਕਿ ਟਰੇਸਬੈਕ ਵਿੱਚ ਹੇਠ ਲਿਖੀ ਜਾਣਕਾਰੀ ਸ਼ਾਮਲ ਹੈ:

  • ਫਾਇਲ “”: ਇਹ ਸਾਨੂੰ ਦੱਸਦਾ ਹੈ ਕਿ ਇਹ ਕੋਡ ਕੰਸੋਲ ਟਰਮੀਨਲ ਤੋਂ ਚਲਾਇਆ ਗਿਆ ਸੀ।
  • ਲਾਈਨ 1: ਇਹ ਸਾਨੂੰ ਦੱਸਦਾ ਹੈ ਕਿ ਇਸ ਲਾਈਨ ਨੰਬਰ ਵਿੱਚ ਗਲਤੀ ਆਈ ਹੈ।
  • ਜ਼ੀਰੋ ਡਿਵੀਜ਼ਨ ਐਰਰ: ਜ਼ੀਰੋ ਦੁਆਰਾ ਵੰਡ: ਇਹ ਸਾਨੂੰ ਦੱਸਦਾ ਹੈ ਕਿ ਕਿਹੜਾ ਅਪਵਾਦ ਪੈਦਾ ਹੋਇਆ ਸੀ ਅਤੇ ਇਸਦਾ ਕਾਰਨ ਕੀ ਸੀ।

ਆਓ ਇੱਕ ਹੋਰ ਉਦਾਹਰਣ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰੋ ਅਤੇ ਸ਼ਾਇਦ ਦੇਖੋ ਕਿ ਇੱਕ ਕਾਲ ਸਟੈਕ ਕਿਵੇਂ ਦਿਖਾਈ ਦਿੰਦਾ ਹੈ। ਇੱਕ ਸੰਪਾਦਕ ਖੋਲ੍ਹੋ, ਹੇਠਾਂ ਕੋਡ ਦਰਜ ਕਰੋ ਅਤੇ 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 

ਡਾਇਰੈਕਟਰੀ ਵਿੱਚ ਇੱਕ ਟਰਮੀਨਲ ਖੋਲ੍ਹੋ ਜਿੱਥੇ ਇਹ ਫਾਈਲ ਲੱਭੀ ਹੈ ਅਤੇ ਚਲਾਈ ਜਾਂਦੀ ਹੈ।

python tracebackExp.py

ਤੁਸੀਂ ਹੇਠਾਂ ਦਿੱਤੀ ਟਰੇਸਬੈਕ ਵੇਖੋਗੇ:

ਉਪਰੋਕਤ ਟਰੇਸਬੈਕ ਉਲਝਣ ਵਾਲਾ ਜਾਪਦਾ ਹੈ ਪਰ ਅਸਲ ਵਿੱਚ ਅਜਿਹਾ ਨਹੀਂ ਹੈ। Pythonistas ਟਰੇਸਬੈਕ ਨੂੰ ਪੜ੍ਹਨ ਦਾ ਸਭ ਤੋਂ ਵਧੀਆ ਤਰੀਕਾ ਲੈ ਕੇ ਆਇਆ ਹੈ, ਜੋ ਕਿ ਬਾਟਮ ਅੱਪ ਤੋਂ ਹੈ। ਇਸ ਲਈ, ਆਓ ਇਸ ਸਿਆਣਪ ਨੂੰ ਅਜ਼ਮਾਉਣ ਅਤੇ ਸਮਝਣ ਲਈ ਵਰਤੀਏ ਕਿ ਇਹ ਟਰੇਸਬੈਕ ਕੀ ਪੇਸ਼ਕਸ਼ ਕਰਦਾ ਹੈ।

  • ਸਭ ਤੋਂ ਹੇਠਾਂ, ਸਾਨੂੰ ਉਹ ਅਪਵਾਦ ਮਿਲਦਾ ਹੈ ਜੋ ਉਠਾਇਆ ਗਿਆ ਸੀ ਅਤੇ ਇਹ ਕਿਉਂ ਉਠਾਇਆ ਗਿਆ ਸੀ।
  • ਉੱਪਰ ਜਾਣ 'ਤੇ, ਸਾਨੂੰ ਫਾਈਲ ਦਾ ਨਾਮ tracebackExp .py ਮਿਲਦਾ ਹੈ ਜਿੱਥੇ ਇਹ ਗਲਤੀ ਆਈ ਹੈ, ਉਹ ਗਣਨਾ ਜਿਸ ਨਾਲ ਇਹ ਗਲਤੀ ਹੋਈ compute = numb/div, ਫੰਕਸ਼ਨ ਸਟੈਕ 2, ਅਤੇ ਲਿੰਕ ਨੰਬਰ ਲਾਈਨ 6 ਜਿੱਥੇ ਇਹ ਗਣਨਾ ਕੀਤੀ ਗਈ ਸੀ। .
  • ਉੱਪਰ ਜਾ ਕੇ, ਅਸੀਂ ਦੇਖਦੇ ਹਾਂ ਕਿ ਸਾਡਾ ਸਟੈਕ2 ਫੰਕਸ਼ਨਲਾਈਨ ਨੰਬਰ 3 ਵਿੱਚ ਫੰਕਸ਼ਨ ਸਟੈਕ1 ਵਿੱਚ ਕਾਲ ਕੀਤੀ ਗਈ ਸੀ।
  • ਉੱਪਰ ਵੱਲ ਵਧਦੇ ਹੋਏ, ਅਸੀਂ ਦੇਖਦੇ ਹਾਂ ਕਿ ਫੰਕਸ਼ਨ ਸਟੈਕ1 ਨੂੰ ਲਾਈਨ ਨੰਬਰ 11 ਵਿੱਚ ਕਾਲ ਕੀਤਾ ਗਿਆ ਸੀ। ਮੋਡਿਊਲ > ਸਾਨੂੰ ਦੱਸਦੀ ਹੈ ਕਿ ਇਹ ਉਹ ਫਾਈਲ ਹੈ ਜਿਸ ਨੂੰ ਚਲਾਇਆ ਜਾ ਰਿਹਾ ਹੈ।

ਆਮ ਪਾਈਥਨ ਅਪਵਾਦ

ਪਾਈਥਨ ਲਾਇਬ੍ਰੇਰੀ ਬਹੁਤ ਸਾਰੇ ਬਿਲਟ-ਇਨ ਅਪਵਾਦਾਂ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦੀ ਹੈ। ਤੁਸੀਂ ਪਾਈਥਨ ਡੌਕੂਮੈਂਟੇਸ਼ਨ ਦੀ ਜਾਂਚ ਕਰ ਸਕਦੇ ਹੋ ਜਾਂ ਬਿਲਟ-ਇਨ ਲੋਕਲ () ਫੰਕਸ਼ਨ ਨੂੰ ਹੇਠਾਂ ਦਿੱਤੇ ਅਨੁਸਾਰ ਕਾਲ ਕਰ ਸਕਦੇ ਹੋ:

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

ਅਸੀਂ ਇਹਨਾਂ ਸਾਰੇ ਅਪਵਾਦਾਂ ਨੂੰ ਹੱਲ ਕਰਨ ਦੀ ਕੋਸ਼ਿਸ਼ ਨਹੀਂ ਕਰਾਂਗੇ, ਪਰ ਅਸੀਂ ਕੁਝ ਆਮ ਅਪਵਾਦ ਦੇਖਾਂਗੇ। ਜੋ ਤੁਹਾਡੇ ਸਾਹਮਣੇ ਆ ਜਾਵੇਗਾ।

#1) TypeError

ਇਹ ਉਦੋਂ ਉਠਾਇਆ ਜਾਂਦਾ ਹੈ ਜਦੋਂ ਕੋਈ ਕਾਰਵਾਈ ਜਾਂ ਫੰਕਸ਼ਨ ਕਿਸੇ ਅਣਉਚਿਤ ਕਿਸਮ ਦੀ ਵਸਤੂ 'ਤੇ ਲਾਗੂ ਹੁੰਦਾ ਹੈ।

ਉਦਾਹਰਨ 1

ਹੇਠਾਂ ਦਿੱਤੇ ਪ੍ਰੋਗਰਾਮ 'ਤੇ ਗੌਰ ਕਰੋ। ਇਹ ਇੱਕ ਲਾਭਅੰਸ਼ ਅਤੇ ਭਾਜਕ ਵਿੱਚ ਲੈਂਦਾ ਹੈ, ਫਿਰ ਭਾਜਕ ਦੁਆਰਾ ਲਾਭਅੰਸ਼ ਨੂੰ ਵੰਡਣ ਦੇ ਨਤੀਜੇ ਦੀ ਗਣਨਾ ਕਰਦਾ ਹੈ ਅਤੇ ਪ੍ਰਿੰਟ ਕਰਦਾ ਹੈ।

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() 

ਅਸੀਂ ਉਪਭੋਗਤਾ ਤੋਂ ਲਾਭਅੰਸ਼ ਅਤੇ ਭਾਜਕ ਦੇ ਮੁੱਲ ਦੀ ਬੇਨਤੀ ਕਰਦੇ ਹਾਂ, ਪਰ ਅਸੀਂ ਭਾਜਕ ਦੀ ਸਤਰ ਨੂੰ ਕਾਸਟ ਕਰਨਾ ਭੁੱਲ ਜਾਂਦੇ ਹਾਂ ਇੱਕ ਪੂਰਨ ਅੰਕ ਵਿੱਚ ਮੁੱਲ. ਇਸ ਲਈ, ਅਸੀਂ ਲਾਭਅੰਸ਼ ਦੀ ਕਿਸਮ ਪੂਰਨ ਅੰਕ ( int ) ਅਤੇ ਵਿਭਾਜਕ ਦੀ ਕਿਸਮ ਸਟਰਿੰਗ ( str ) ਹੋਣ ਦੇ ਨਾਲ ਖਤਮ ਹੁੰਦੇ ਹਾਂ। ਫਿਰ ਸਾਨੂੰ TypeError ਮਿਲਦਾ ਹੈ ਕਿਉਂਕਿ ਡਿਵੀਜ਼ਨ ਆਪਰੇਟਰ (/) ਸਟਰਿੰਗਾਂ 'ਤੇ ਕੰਮ ਨਹੀਂ ਕਰਦਾ।

ਤੁਹਾਨੂੰ ਇਹ ਜਾਣਨਾ ਦਿਲਚਸਪ ਹੋ ਸਕਦਾ ਹੈ ਕਿ ਪਾਈਥਨ ਦੇ ਉਲਟ, ਜਾਵਾਸਕ੍ਰਿਪਟ ਵਿੱਚ ਟਾਈਪ ਜ਼ਬਰਦਸਤੀ ਹੈ ਜੋ ਮੂਲ ਰੂਪ ਵਿੱਚ ਇੱਕ ਓਪਰੇਂਡ ਦੀ ਕਿਸਮ ਨੂੰ ਦੂਜੇ ਓਪਰੇਂਡ ਦੀ ਕਿਸਮ ਦੇ ਬਰਾਬਰ ਮੁੱਲ ਵਿੱਚ ਬਦਲਦੀ ਹੈ ਜਦੋਂ ਓਪਰੇਂਡਵੱਖ-ਵੱਖ ਕਿਸਮਾਂ।

#2) ValueError

ਇਹ ਉਦੋਂ ਉਠਾਇਆ ਜਾਂਦਾ ਹੈ ਜਦੋਂ ਇੱਕ ਓਪਰੇਸ਼ਨ ਜਾਂ ਫੰਕਸ਼ਨ ਇੱਕ ਆਰਗੂਮੈਂਟ ਪ੍ਰਾਪਤ ਕਰਦਾ ਹੈ ਜਿਸ ਵਿੱਚ ਸਹੀ ਕਿਸਮ ਹੈ ਪਰ ਇੱਕ ਅਣਉਚਿਤ ਮੁੱਲ ਹੈ।

ਉਦਾਹਰਨ 2

ਉਪਰੋਕਤ ਉਦਾਹਰਨ 1 ਵਿੱਚ ਸਾਡੇ ਪ੍ਰੋਗਰਾਮ 'ਤੇ ਵਿਚਾਰ ਕਰੋ।

ਜੇਕਰ ਉਪਭੋਗਤਾ '3a' ਵਰਗੇ ਲਾਭਅੰਸ਼ ਲਈ ਇੱਕ ਅਲਫਾਨਿਊਮੇਰਿਕ ਮੁੱਲ ਇਨਪੁੱਟ ਕਰਦਾ ਹੈ, ਤਾਂ ਸਾਡਾ ਪ੍ਰੋਗਰਾਮ ਵਧੇਗਾ। ValueError ਅਪਵਾਦ। ਇਹ ਇਸ ਲਈ ਹੈ ਕਿਉਂਕਿ, ਭਾਵੇਂ Python int() ਵਿਧੀ ਕਿਸੇ ਵੀ ਸੰਖਿਆ ਜਾਂ ਸਟ੍ਰਿੰਗ ਨੂੰ ਲੈਂਦੀ ਹੈ ਅਤੇ ਇੱਕ ਪੂਰਨ ਅੰਕ ਆਬਜੈਕਟ ਵਾਪਸ ਕਰਦੀ ਹੈ, ਸਟ੍ਰਿੰਗ ਮੁੱਲ ਵਿੱਚ ਅੱਖਰ ਜਾਂ ਕੋਈ ਗੈਰ-ਸੰਖਿਆਤਮਕ ਮੁੱਲ ਨਹੀਂ ਹੋਣਾ ਚਾਹੀਦਾ ਹੈ।

#3) ਐਟਰੀਬਿਊਟ ਐਰਰ

ਇਹ ਅਪਵਾਦ ਕਿਸੇ ਵਿਸ਼ੇਸ਼ਤਾ ਨੂੰ ਨਿਰਧਾਰਤ ਕਰਨ ਜਾਂ ਸੰਦਰਭ ਦੇਣ ਵੇਲੇ ਉਠਾਇਆ ਜਾਂਦਾ ਹੈ ਜੋ ਮੌਜੂਦ ਨਹੀਂ ਹੈ।

ਉਦਾਹਰਨ 3

ਪ੍ਰੋਗਰਾਮ 'ਤੇ ਗੌਰ ਕਰੋ ਹੇਠਾਂ। ਇਹ ਇੱਕ ਨੰਬਰ ਲੈਂਦਾ ਹੈ ਅਤੇ ਪਾਈਥਨ ਮੈਥ ਮੋਡੀਊਲ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਇਸਦੇ ਵਰਗ ਰੂਟ ਦੀ ਗਣਨਾ ਕਰਦਾ ਹੈ

import math # import math library to gain access to its code def compute_square_root(number): # compute the square root using the math library result = math.sqr(number) return result if __name__ == '__main__': # get input to compute from user number = int(input("Compute Square root of: ")) # call function to compute square root 

ਜਦੋਂ ਇੱਕ ਉਪਭੋਗਤਾ ਇੱਕ ਨੰਬਰ ਦਾਖਲ ਕਰਦਾ ਹੈ, ਸਾਡਾ ਪ੍ਰੋਗਰਾਮ ਇਸਦੇ ਵਰਗ ਰੂਟ ਦੀ ਗਣਨਾ ਕਰਨ ਲਈ ਗਣਿਤ ਮੋਡੀਊਲ ਤੋਂ ਇੱਕ ਫੰਕਸ਼ਨ ਦੀ ਵਰਤੋਂ ਕਰਨ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰਦਾ ਹੈ ਪਰ ਇੱਥੇ, ਅਸੀਂ ਇੱਕ ਗਲਤੀ ਕੀਤੀ ਹੈ। sqrt ਦੀ ਬਜਾਏ, ਅਸੀਂ ਗਲਤੀ ਨਾਲ sqr ਟਾਈਪ ਕਰ ਦਿੱਤਾ ਜੋ ਗਣਿਤ ਮੋਡੀਊਲ ਵਿੱਚ ਮੌਜੂਦ ਨਹੀਂ ਹੈ।

ਇਸ ਲਈ, ਅਸੀਂ ਇੱਕ ਵਿਸ਼ੇਸ਼ਤਾ sqr ਦਾ ਹਵਾਲਾ ਦੇਣ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰ ਰਹੇ ਸੀ ਜੋ ਮੌਜੂਦ ਨਹੀਂ ਹੈ ਅਤੇ ਅਗਵਾਈ ਅਪਵਾਦ ਐਟਰੀਬਿਊਟ ਐਰਰ ਨੂੰ ਉਠਾਇਆ ਜਾ ਰਿਹਾ ਹੈ। ਸਾਡੇ ਵਿੱਚੋਂ ਜ਼ਿਆਦਾਤਰ ਇਸ ਤਰ੍ਹਾਂ ਦੀ ਗਲਤੀ ਬਹੁਤ ਕਰਦੇ ਹਨ। ਇਸ ਲਈ, ਤੁਸੀਂ ਇਕੱਲੇ ਨਹੀਂ ਹੋ।

ਅਪਵਾਦਾਂ ਨੂੰ ਅਜ਼ਮਾਉਣ ਦੇ ਨਾਲ ਸੰਭਾਲਣਾ

ਇੱਕ ਪ੍ਰੋਗਰਾਮਰ ਵਜੋਂ, ਇੱਕ ਚੀਜ਼ ਜਿਸ 'ਤੇ ਸਾਡੇ ਵਿੱਚੋਂ ਜ਼ਿਆਦਾਤਰ ਆਪਣਾ ਸਮਾਂ ਬਿਤਾਉਂਦੇ ਹਨ ਉਹ ਹੈ ਇੱਕ ਮਜ਼ਬੂਤ ​​ਕੋਡ ਲਿਖਣਾਲਚਕੀਲਾ ਕੋਡ ਜੋ ਕੁਝ ਗਲਤੀਆਂ ਦੇ ਕਾਰਨ ਨਹੀਂ ਟੁੱਟਦਾ ਹੈ। ਪਾਈਥਨ ਵਿੱਚ, ਅਸੀਂ ਇੱਕ ਕੋਸ਼ਿਸ਼ ਸਿਵਾਏ ਸਟੇਟਮੈਂਟ ਦੇ ਅੰਦਰ ਆਪਣੇ ਸਟੇਟਮੈਂਟਾਂ ਨੂੰ ਨੱਥੀ ਕਰਕੇ ਇਸਨੂੰ ਪ੍ਰਾਪਤ ਕਰ ਸਕਦੇ ਹਾਂ।

ਪਾਈਥਨ ਟਰਾਈ-ਐਕਸੈਪਟ ਸਟੇਟਮੈਂਟ

ਟ੍ਰਾਈ-ਸਿਵਾਏ ਸਟੇਟਮੈਂਟ ਦੀ ਹੇਠ ਲਿਖੀ ਬਣਤਰ ਹੈ:

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

ਆਓ ਕੋਡ ਨੂੰ tracebackExp .py ਵਿੱਚ ਇੱਕ ਕੋਸ਼ਿਸ਼-ਸਿਵਾਏ ਸਟੇਟਮੈਂਟ ਦੇ ਅੰਦਰ ਨੱਥੀ ਕਰੀਏ।

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 

ਇਸ ਕੋਡ ਨੂੰ ਚਲਾਉਣ ਨਾਲ ਆਉਟਪੁੱਟ ਪੈਦਾ ਹੋਵੇਗੀ

ਇਸ ਤਰ੍ਹਾਂ ਕੋਸ਼ਿਸ਼-ਸਿਵਾਏ ਸਟੇਟਮੈਂਟ ਕੰਮ ਕਰਦੀ ਹੈ। Python ਕੋਡ ਨੂੰ ਟਰਾਈ ਬਲਾਕ ਲਾਈਨ 7-8 ਵਿੱਚ ਚਲਾਉਂਦਾ ਹੈ। ਜੇਕਰ ਕੋਈ ਅਵੈਧ ਕੋਡ ਨਹੀਂ ਮਿਲਦਾ, ਤਾਂ ਬਲਾਕ ਲਾਈਨ 10 ਨੂੰ ਛੱਡ ਕੇ ਕੋਡ ਨੂੰ ਛੱਡ ਦਿੱਤਾ ਜਾਂਦਾ ਹੈ ਅਤੇ ਐਗਜ਼ੀਕਿਊਸ਼ਨ ਜਾਰੀ ਰਹਿੰਦਾ ਹੈ।

ਪਰ, ਜੇਕਰ ਕੋਈ ਗਲਤ ਕੋਡ ਮਿਲਦਾ ਹੈ, ਤਾਂ ਐਗਜ਼ੀਕਿਊਸ਼ਨ ਤੁਰੰਤ ਬੰਦ ਹੋ ਜਾਂਦਾ ਹੈ। ਬਲਾਕ ਕਰਨ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰੋ ਅਤੇ ਜਾਂਚ ਕਰੋ ਕਿ ਕੀ ਅਪਵਾਦ ਉਠਾਇਆ ਗਿਆ ਉਸ ਨਾਲ ਮੇਲ ਖਾਂਦਾ ਹੈ ਜੋ ਅਸੀਂ ਸਿਵਾਏਟ ਸਟੇਟਮੈਂਟ ਲਾਈਨ 9 ਵਿੱਚ ਪ੍ਰਦਾਨ ਕੀਤਾ ਹੈ। ਜੇਕਰ ਇਹ ਮੇਲ ਖਾਂਦਾ ਹੈ, ਤਾਂ ਸਿਵਾਏ ਬਲਾਕ ਨੂੰ ਚਲਾਇਆ ਜਾਂਦਾ ਹੈ ਅਤੇ ਜਾਰੀ ਰਹਿੰਦਾ ਹੈ। ਜੇਕਰ ਅਜਿਹਾ ਨਹੀਂ ਹੁੰਦਾ, ਤਾਂ ਪ੍ਰੋਗਰਾਮ ਵਿੱਚ ਰੁਕਾਵਟ ਆਵੇਗੀ।

ਟ੍ਰਾਈ-ਬਲਾਕ ਵਿੱਚ ਆਮ ਤੌਰ 'ਤੇ ਉਹ ਕੋਡ ਹੁੰਦਾ ਹੈ ਜੋ ਇੱਕ ਅਪਵਾਦ ਪੈਦਾ ਕਰ ਸਕਦਾ ਹੈ ਜਦੋਂ ਕਿ ਸਿਵਾਏ-ਬਲਾਕ ਅਪਵਾਦ ਨੂੰ ਫੜਦਾ ਅਤੇ ਹੈਂਡਲ ਕਰਦਾ ਹੈ।

ਮਲਟੀਪਲ ਹੈਂਡਲਿੰਗ ਸਿਵਾਏ ਦੇ ਨਾਲ ਅਪਵਾਦ

ਅਸੀਂ ਇੱਕ "ਸਿਵਾਏ" ਜਾਂ ਕਈ "ਸਿਵਾਏ" ਦੇ ਨਾਲ ਕਈ ਅਪਵਾਦਾਂ ਨੂੰ ਸੰਭਾਲ ਸਕਦੇ ਹਾਂ। ਇਹ ਸਭ ਇਸ ਗੱਲ 'ਤੇ ਨਿਰਭਰ ਕਰਦਾ ਹੈ ਕਿ ਤੁਸੀਂ ਹਰੇਕ ਅਪਵਾਦ ਨੂੰ ਕਿਵੇਂ ਹੈਂਡਲ ਕਰਨਾ ਚਾਹੁੰਦੇ ਹੋ।

#1) ਇੱਕ ਸਿੰਗਲ ਸਿਵਾਏ ਨਾਲ ਮਲਟੀਪਲ ਅਪਵਾਦਾਂ ਨੂੰ ਸੰਭਾਲਣਾ

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

ਇਹ ਵਿਧੀ ਉਦੋਂ ਵਰਤੀ ਜਾਂਦੀ ਹੈ ਜਦੋਂ ਸਾਨੂੰ ਸ਼ੱਕ ਹੁੰਦਾ ਹੈ ਕਿ ਸਾਡਾ ਕੋਡ ਹੋ ਸਕਦਾ ਹੈਵੱਖੋ-ਵੱਖਰੇ ਅਪਵਾਦ ਉਠਾਓ ਅਤੇ ਅਸੀਂ ਹਰੇਕ ਮਾਮਲੇ ਵਿੱਚ ਇੱਕੋ ਜਿਹੀ ਕਾਰਵਾਈ ਕਰਨਾ ਚਾਹੁੰਦੇ ਹਾਂ। ਇਸ ਲਈ, ਜੇਕਰ ਪਾਈਥਨ ਦੁਭਾਸ਼ੀਏ ਨੂੰ ਕੋਈ ਮੇਲ ਲੱਭਦਾ ਹੈ, ਤਾਂ ਸਿਵਾਏਟ ਬਲਾਕ ਵਿੱਚ ਲਿਖਿਆ ਕੋਡ ਚਲਾਇਆ ਜਾਵੇਗਾ।

ਆਓ ਹੇਠਾਂ ਪਾਈਥਨ ਕੋਡ ਦੀ ਉਦਾਹਰਣ 'ਤੇ ਵਿਚਾਰ ਕਰੀਏ

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) 

ਸਾਡੇ ਕੋਲ ਦੋ ਹਨ ਸੰਭਵ ਅਪਵਾਦ ਜੋ ਇੱਥੇ ਉਠਾਏ ਜਾ ਸਕਦੇ ਹਨ, ZeroDivisionError ਅਤੇ IndexError । ਜੇਕਰ ਇਹਨਾਂ ਵਿੱਚੋਂ ਕੋਈ ਵੀ ਅਪਵਾਦ ਵਧਾਇਆ ਜਾਂਦਾ ਹੈ, ਤਾਂ ਸਿਵਾਏ ਬਲਾਕ ਨੂੰ ਚਲਾਇਆ ਜਾਵੇਗਾ।

ਉਪਰੋਕਤ ਕੋਡ ਵਿੱਚ, idx=3, ਇਸਲਈ idx_ ਮੁੱਲ 0 ਅਤੇ ਮੁੱਲ ਬਣ ਜਾਂਦਾ ਹੈ। /idx_ ਮੁੱਲ ZeroDivisionError ਵਧਾਏਗਾ

#2) ਮਲਟੀਪਲ ਅਪਵਾਦਾਂ ਨੂੰ ਮਲਟੀਪਲ ਅਪਵਾਦਾਂ ਨਾਲ ਹੈਂਡਲ ਕਰਨਾ

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

ਜੇਕਰ ਅਸੀਂ ਇਸ ਨੂੰ ਸੰਭਾਲਣਾ ਚਾਹੁੰਦੇ ਹਾਂ ਹਰੇਕ ਅਪਵਾਦ ਨੂੰ ਵੱਖਰੇ ਤੌਰ 'ਤੇ, ਫਿਰ ਤੁਸੀਂ ਇਸ ਤਰ੍ਹਾਂ ਕਰ ਸਕਦੇ ਹੋ।

ਹੇਠਾਂ ਦਿੱਤੇ ਪਾਇਥਨ ਕੋਡ ਦੀ ਉਦਾਹਰਨ 'ਤੇ ਗੌਰ ਕਰੋ

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 

ਅਸੀਂ ਇੱਥੇ ਨੋਟਿਸ ਕਰਦੇ ਹਾਂ ਕਿ ਅਪਵਾਦ ਆਖਰੀ ਸਿਵਾਏ ਸਟੇਟਮੈਂਟ ਵਿੱਚ ਵਰਤਿਆ ਗਿਆ ਸੀ। . ਇਹ ਇਸ ਲਈ ਹੈ ਕਿਉਂਕਿ ਅਪਵਾਦ ਵਸਤੂ ਅਪਵਾਦ ਕਿਸੇ ਅਪਵਾਦ ਨਾਲ ਮੇਲ ਖਾਂਦਾ ਹੈ। ਇਸ ਕਾਰਨ ਕਰਕੇ, ਇਹ ਹਮੇਸ਼ਾ ਆਖਰੀ ਹੋਣਾ ਚਾਹੀਦਾ ਹੈ, ਕਿਉਂਕਿ ਪਾਇਥਨ ਦੂਜੇ ਅਪਵਾਦ ਹੈਂਡਲਰਾਂ ਦੀ ਜਾਂਚ ਕਰਨਾ ਬੰਦ ਕਰ ਦੇਵੇਗਾ ਇੱਕ ਵਾਰ ਮੇਲ ਖਾਂਦਾ ਹੈ।

ਉਪਰੋਕਤ ਕੋਡ ਵਿੱਚ, idx=5 , ਇਸਲਈ arr[idx ] ਵਧਾਏਗਾ IndexError ਕਿਉਂਕਿ idx ਸੂਚੀ ਦੀ ਲੰਬਾਈ ਤੋਂ ਵੱਧ ਹੈ arr

ਨਾਲ ਹੀ, ਇਹ ਯਕੀਨੀ ਨਹੀਂ ਕਿ ਤੁਹਾਡੀ ਅਰਜ਼ੀ ਦੁਆਰਾ ਕਿਹੜਾ ਅਪਵਾਦ ਉਠਾਇਆ ਗਿਆ ਸੀ, ਐਗਜ਼ੀਕਿਊਸ਼ਨ ਜਾਰੀ ਰੱਖਣ ਲਈ ਕਦੇ ਵੀ ਸੁਰੱਖਿਅਤ ਨਹੀਂ ਹੈ। ਇਸ ਲਈ ਸਾਡੇ ਕੋਲ ਕਿਸੇ ਵੀ ਅਣਪਛਾਤੇ ਅਪਵਾਦ ਨੂੰ ਫੜਨ ਲਈ ਅਪਵਾਦ ਦੀ ਕਿਸਮ ਹੈ। ਫਿਰ, ਅਸੀਂ ਸੂਚਿਤ ਕਰਦੇ ਹਾਂਉਪਯੋਗਕਰਤਾ ਅਤੇ ਉਸੇ ਅਪਵਾਦ ਨੂੰ ਵਧਾ ਕੇ ਐਪਲੀਕੇਸ਼ਨ ਨੂੰ ਰੋਕੋ।

ਹੋਰ ਬਿਆਨ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰੋ

ਇਹ ਅਪਵਾਦ ਹੈਂਡਲਿੰਗ ਦੀ ਇੱਕ ਵਿਕਲਪਿਕ ਵਿਸ਼ੇਸ਼ਤਾ ਹੈ ਅਤੇ ਤੁਹਾਨੂੰ ਉਹ ਕੋਡ ਜੋੜਨ ਦੀ ਇਜਾਜ਼ਤ ਦਿੰਦਾ ਹੈ ਜੋ ਤੁਸੀਂ ਚਾਹੁੰਦੇ ਹੋ। ਚਲਾਓ ਜਦੋਂ ਕੋਈ ਗਲਤੀ ਨਹੀਂ ਹੋਈ। ਜੇਕਰ ਕੋਈ ਤਰੁੱਟੀ ਹੁੰਦੀ ਹੈ, ਤਾਂ ਇਹ ਹੋਰ-ਬਲਾਕ ਨਹੀਂ ਚੱਲੇਗਾ।

ਹੇਠਾਂ ਦਿੱਤੇ ਪਾਈਥਨ ਕੋਡ ਦੀ ਉਦਾਹਰਨ 'ਤੇ ਗੌਰ ਕਰੋ, ਆਪਣਾ ਸੰਪਾਦਕ ਖੋਲ੍ਹੋ ਅਤੇ ਕੋਡ ਨੂੰ 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 
0 ਦੇ ਰੂਪ ਵਿੱਚ ਸੁਰੱਖਿਅਤ ਕਰੋ।>ਅਸੀਂ ਉਪਭੋਗਤਾ ਤੋਂ ਇਨਪੁਟ ਪ੍ਰਾਪਤ ਕਰਦੇ ਹਾਂ ਅਤੇ ਇਸਨੂੰ 1 ਨੂੰ ਵੰਡਣ ਲਈ ਵਰਤਦੇ ਹਾਂ। ਸਾਡੇ ਕੋਲ ਇੱਥੇ ਦੋ ਸੰਭਾਵੀ ਅਪਵਾਦ ਹਨ, ਇੱਕ ਅਵੈਧ ਉਪਭੋਗਤਾ ਇਨਪੁਟ ਜੋ ValueErrorਅਤੇ ਇੱਕ ਜ਼ੀਰੋ(0)ਦਾ ਕਾਰਨ ਬਣੇਗਾ। ਜ਼ੀਰੋ ਡਿਵੀਜ਼ਨ ਐਰਰ। ਸਾਡਾ ਸਿਵਾਏ ਸਟੇਟਮੈਂਟ ਇਹਨਾਂ ਗਲਤੀਆਂ ਨੂੰ ਸੰਭਾਲਦਾ ਹੈ।

ਹੁਣ, ਅਸੀਂ ਮੁੱਲ ਦਾ ਮੁੱਲ ਪ੍ਰਿੰਟ ਕਰਨਾ ਚਾਹੁੰਦੇ ਹਾਂ। ਸਾਡਾ ਹੋਰ-ਬਲਾਕ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਇਹ ਕੇਵਲ ਤਾਂ ਹੀ ਛਾਪਿਆ ਗਿਆ ਹੈ ਜੇਕਰ ਸਾਡੀ ਕੋਸ਼ਿਸ਼ ਬਲਾਕ ਬਿਨਾਂ ਕਿਸੇ ਗਲਤੀ ਦੇ ਚੱਲਦੀ ਹੈ। ਇਹ ਮਹੱਤਵਪੂਰਨ ਹੈ ਕਿਉਂਕਿ ਜੇਕਰ ਸਾਡੇ ਟ੍ਰਾਈ-ਬਲਾਕ ਵਿੱਚ ਕੋਈ ਗਲਤੀ ਆਉਂਦੀ ਹੈ, ਤਾਂ ਮੁੱਲ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਨਹੀਂ ਕੀਤਾ ਜਾਵੇਗਾ। ਇਸ ਲਈ, ਇਸ ਨੂੰ ਐਕਸੈਸ ਕਰਨ ਨਾਲ ਇੱਕ ਹੋਰ ਗਲਤੀ ਪੈਦਾ ਹੋ ਜਾਵੇਗੀ।

ਉਪਰੋਕਤ ਕੋਡ ਨੂੰ Python elseTry.py ਨਾਲ ਚਲਾਓ

ਉਪਰੋਕਤ ਆਉਟਪੁੱਟ ਦਿਖਾਉਂਦਾ ਹੈ ਕਿ ਪਹਿਲੇ ਇੰਪੁੱਟ ਲਈ, ਅਸੀਂ 0 ਟਾਈਪ ਕੀਤਾ ਅਤੇ ENTER ਦਬਾਇਆ। ਕਿਉਂਕਿ ਸਾਡੇ ਭਾਜਕ ਨੇ 0 ਪ੍ਰਾਪਤ ਕੀਤਾ, 1/ਭਾਜਕ ਨੇ ਜ਼ੀਰੋ ਡਿਵੀਜ਼ਨ ਐਰਰ ਉਠਾਇਆ। ਸਾਡਾ ਦੂਜਾ ਇੰਪੁੱਟ k ਸੀ ਜੋ int () ਲਈ ਅਵੈਧ ਹੈ, ਇਸਲਈ ਅਪਵਾਦ ValueError ਉਠਾਇਆ ਗਿਆ ਹੈ।

ਪਰ ਸਾਡਾ ਆਖਰੀ ਇੰਪੁੱਟ 9 ਸੀ ਜੋ ਵੈਧ ਹੈ ਅਤੇ a ਦੇ ਰੂਪ ਵਿੱਚ ਨਤੀਜਾ, ਸਾਨੂੰ " ਮੁੱਲ " ਦਾ ਮੁੱਲ 0.1111111111111111

ਅੰਤ ਵਿੱਚ ਅਜ਼ਮਾਓਕਥਨ

ਇਹ ਅਪਵਾਦ ਹੈਂਡਲਿੰਗ ਦੀ ਇੱਕ ਵਿਕਲਪਿਕ ਵਿਸ਼ੇਸ਼ਤਾ ਵੀ ਹੈ ਅਤੇ ਇਹ ਹਮੇਸ਼ਾ ਚੱਲੇਗੀ ਭਾਵੇਂ ਅਪਵਾਦ ਹੈਂਡਲਰਾਂ ਵਿੱਚ ਕੁਝ ਵੀ ਹੋਵੇ।

ਇਹ ਹੈ:

  • ਕੀ ਕੋਈ ਅਪਵਾਦ ਆਉਂਦਾ ਹੈ ਜਾਂ ਨਹੀਂ
  • ਭਾਵੇਂ ਇੱਕ 'ਰਿਟਰਨ' ਨੂੰ ਦੂਜੇ ਬਲਾਕਾਂ ਵਿੱਚ ਬੁਲਾਇਆ ਜਾਂਦਾ ਹੈ।
  • ਭਾਵੇਂ ਸਕ੍ਰਿਪਟ ਨੂੰ ਦੂਜੇ ਬਲਾਕਾਂ ਵਿੱਚ ਬੰਦ ਕੀਤਾ ਜਾਂਦਾ ਹੈ

ਇਸ ਲਈ, ਜੇਕਰ ਸਾਡੇ ਕੋਲ ਇੱਕ ਕੋਡ ਹੈ ਜੋ ਅਸੀਂ ਸਾਰੀਆਂ ਸਥਿਤੀਆਂ ਵਿੱਚ ਚਲਾਉਣਾ ਚਾਹੁੰਦੇ ਹਾਂ, ਅੰਤ ਵਿੱਚ-ਬਲਾਕ ਸਾਡਾ ਮੁੰਡਾ ਹੈ। ਇਹ ਬਲਾਕ ਜ਼ਿਆਦਾਤਰ ਕਲੀਨ-ਅੱਪ ਜਿਵੇਂ ਕਿ ਫਾਈਲਾਂ ਨੂੰ ਬੰਦ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ।

ਹੇਠਾਂ ਦਿੱਤੇ ਪਾਈਥਨ ਕੋਡ ਦੀ ਉਦਾਹਰਨ 'ਤੇ ਗੌਰ ਕਰੋ

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) 

ਇਹ ਕੋਡ ਫਾਈਲ ਨੂੰ ਖੋਲ੍ਹਣ ਅਤੇ ਪੜ੍ਹਨ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰਦਾ ਹੈ text.txt ਇਸਦੀ ਮੌਜੂਦਾ ਡਾਇਰੈਕਟਰੀ ਵਿੱਚ. ਜੇਕਰ ਫਾਈਲ ਮੌਜੂਦ ਹੈ, ਤਾਂ ਸਾਡਾ ਪ੍ਰੋਗਰਾਮ ਫਾਈਲ ਦੀ ਪਹਿਲੀ ਲਾਈਨ ਨੂੰ ਪ੍ਰਿੰਟ ਕਰੇਗਾ, ਫਿਰ ਸਾਡਾ ਅੰਤਮ-ਬਲੌਕ ਚੱਲੇਗਾ ਅਤੇ ਫਾਈਲ ਨੂੰ ਬੰਦ ਕਰ ਦੇਵੇਗਾ।

ਕਹੋ ਕਿ ਸਾਡੇ ਕੋਲ ਡਾਇਰੈਕਟਰੀ ਵਿੱਚ text.txt ਨਾਮ ਦੀ ਇੱਕ ਫਾਈਲ ਹੈ ਜਿੱਥੇ ਇਹ ਪ੍ਰੋਗਰਾਮ ਫਾਈਲ ਹੈ ਹੈ ਅਤੇ ਹੈਲੋ ਸ਼ਾਮਲ ਕਰਦਾ ਹੈ। ਜੇਕਰ ਅਸੀਂ ਪ੍ਰੋਗਰਾਮ ਚਲਾਉਂਦੇ ਹਾਂ, ਤਾਂ ਸਾਡੇ ਕੋਲ ਆਉਟਪੁੱਟ ਹੋਵੇਗੀ

ਇਹ ਉਦਾਹਰਨ ਜਾਣਬੁੱਝ ਕੇ ਚੁਣੀ ਗਈ ਸੀ ਕਿਉਂਕਿ ਮੈਂ ਚਾਹੁੰਦਾ ਸੀ ਕਿ ਅਸੀਂ ਇੱਕ ਛੋਟੀ ਜਿਹੀ ਸਮੱਸਿਆ ਨੂੰ ਹੱਲ ਕਰੀਏ ਜੋ ਅੰਤ ਵਿੱਚ ਫਾਈਲਾਂ ਨੂੰ ਬੰਦ ਕਰਨ ਵੇਲੇ ਹੋ ਸਕਦੀ ਹੈ- ਬਲਾਕ।

ਜੇਕਰ ਫ਼ਾਈਲ ਮੌਜੂਦ ਨਹੀਂ ਹੈ, ਤਾਂ ਅਪਵਾਦ FileNotFoundError ਨੂੰ ਉਭਾਰਿਆ ਜਾਵੇਗਾ ਅਤੇ ਵੇਰੀਏਬਲ openFile ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਨਹੀਂ ਕੀਤਾ ਜਾਵੇਗਾ ਅਤੇ ਇੱਕ ਫ਼ਾਈਲ ਨਹੀਂ ਹੋਵੇਗੀ। ਵਸਤੂ। ਇਸ ਲਈ, ਅੰਤਮ-ਬਲਾਕ ਵਿੱਚ ਇਸਨੂੰ ਬੰਦ ਕਰਨ ਦੀ ਕੋਸ਼ਿਸ਼ ਇੱਕ ਅਪਵਾਦ UnboundLocalError ਪੈਦਾ ਕਰੇਗੀ ਜੋ ਕਿ NameError ਦਾ ਇੱਕ ਉਪ-ਕਲਾਸ ਹੈ।

ਇਹ ਮੂਲ ਰੂਪ ਵਿੱਚ ਇਹ ਕਹਿੰਦਾ ਹੈ ਕਿ ਅਸੀਂ ਹਵਾਲਾ ਦੇਣ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰ ਰਹੇ ਹਾਂ। ਦੀ

ਉੱਪਰ ਸਕ੍ਰੋਲ ਕਰੋ