یہ ٹیوٹوریل پروگرامنگ مثالوں کی مدد سے Try Except بلاک کا استعمال کرتے ہوئے Python میں Exception ہینڈلنگ کی وضاحت کرتا ہے:
دو غلطیوں کی وجہ سے Python پروگرام اچانک بند ہو سکتا ہے یعنی Syntax غلطیاں ، اور استثنیات ۔ اس ٹیوٹوریل میں، ہم کئی اہم عنوانات کے تحت غلطی کی دوسری قسم (استثنیات) پر بات کریں گے۔
ہمیں اپنی درخواست میں مستثنیات سے نمٹنے سے بہت فائدہ ہوگا جیسے:
- ایک مضبوط ایپلیکیشن بنانا۔
- صاف اور غلطی سے پاک کوڈ بنانا۔
Python Try Except
ایک اچھی خبر یہ ہے کہ ہمارے کوڈ میں غلطیوں کو پکڑنے کے لیے Python کے پاس بلٹ ان مستثنیات کی ایک اچھی تعداد ہے۔ نیز، یہ ہمیں اپنی مرضی کے مستثنیات تخلیق کرنے کا موقع فراہم کرتا ہے جب کوئی بھی بلٹ ان استثناء ہماری ضروریات کے مطابق نہ ہو۔
ایک استثناء کیا ہے
تو پائتھون میں کیا استثنا ہے؟ ٹھیک ہے، سادہ الفاظ میں، جب بھی Python انٹرپریٹر غلط کوڈ پر عمل درآمد کرنے کی کوشش کرتا ہے، تو یہ ایک استثناء پیدا کرتا ہے، اور ایسی صورتوں میں جہاں اس استثنا کو نہیں سنبھالا جاتا، یہ پروگرام کی ہدایات کے معمول کے بہاؤ میں خلل ڈالتا ہے اور ایک ٹریس بیک پرنٹ کرتا ہے۔
آئیے ایک غلط کوڈ بناتے ہیں اور دیکھتے ہیں کہ 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")
ہمیں ٹریس بیک ملے گا:
تو، مستثنیات کو بڑھانا کیوں ضروری ہے؟
- اپنی مرضی کے مستثنیات کے ساتھ کام کرتے وقت۔
- صاف کی جانچ کے دوران۔
اپنی مرضی کے استثناء کی کلاسیں
ایک حسب ضرورت رعایت وہ ہے جسے آپ اپنی ضرورت کے لیے مخصوص غلطیوں کو سنبھالنے کے لیے بناتے ہیں۔ چال یہ ہے کہ، ہم ایک ایسی کلاس کی وضاحت کرتے ہیں جو آبجیکٹ Exception سے اخذ کرتا ہے، پھر ہم اپنی استثنائی کلاس کو بڑھانے کے لیے raise اسٹیٹمنٹ استعمال کرتے ہیں۔
فرض کریں کہ ہم صارف کے ان پٹ کو چیک کرنا چاہتے ہیں اور یقینی بنانا چاہتے ہیں ان پٹ ویلیو منفی نہیں ہے (سینٹی چیک)۔ بلاشبہ، ہم Python کے استثنا ValueError کو بڑھا سکتے ہیں لیکن ہم اسے ایک مخصوص اور خود وضاحتی نام دے کر اپنی مرضی کے مطابق کرنا چاہیں گے جیسا کہ InputIsNegativeError ۔ لیکن یہ استثنیٰ ازگر ان بلٹ نہیں ہے۔استثنیٰ۔
تو پہلے، ہم اپنی بیس کلاس بناتے ہیں جو Exception سے اخذ کرے گی۔
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، پھر ہمارے پاس آؤٹ پٹ ہوگا:
ازگر کی اپنی مرضی کے مستثنیات کے بارے میں مزید تفصیلات کے لیے Python doc دیکھیں۔
اکثر پوچھے جانے والے سوالات
س # 1) ازگر کسی استثنا کو کیسے ہینڈل کرتا ہے؟
جواب: ازگر کا استعمال کرتے ہوئے استثنیٰ کو ہینڈل کرتا ہے۔ کوشش کے علاوہ بیان ۔ کوڈ جو استثنیٰ کو بڑھا سکتا ہے اسے ٹرائی بلاک میں رکھا اور عمل میں لایا جاتا ہے جب کہ بلاک کے علاوہ میں وہ کوڈ ہوتا ہے جو مستثنیات کو سنبھالے گا اگر کوئی پیدا ہوتا ہے۔
Q #3) Python متعدد استثناء کو کیسے ہینڈل کرتا ہے؟
جواب: ازگر متعدد استثناء کو ہینڈل کرتا ہے۔بلاک کے علاوہ ایک یا ایک سے زیادہ بلاکس کا استعمال کرتے ہوئے۔
ایک بلاک کے لیے، مستثنیات کو ٹیوپل کے طور پر پاس کیا جاتا ہے: سوائے (Exception1, Exception2,..,ExceptionN) اور Python چیک دائیں سے بائیں میچ کے لیے۔ اس صورت میں، ہر استثنیٰ کے لیے ایک ہی کارروائی کی جاتی ہے۔
تمام مستثنیات کو پکڑنے کا ایک اور طریقہ یہ ہے کہ سوائے کلیدی لفظ کے بعد استثناء کا نام چھوڑ دیا جائے۔
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) آپ Python میں کسی استثناء کو کیسے نظر انداز کرتے ہیں؟
جواب: Python میں کسی استثناء کو نظر انداز کرنے کے لیے، سوائے بلاک میں pass کلیدی لفظ استعمال کریں۔ ہم کہتے ہیں کہ ہم ValueError کی رعایت کو نظر انداز کرنا چاہتے ہیں۔ ہم اسے اس طرح کریں گے:
except ValueError: pass
جب تک آپ کو معلوم نہ ہو کہ آپ کیا کر رہے ہیں، مستثنیات کو نظر انداز کرنا برا عمل ہے۔ کم از کم، تمام ممکنہ غلطیوں کے بارے میں صارف کو مطلع کریں۔
نتیجہ
اس ٹیوٹوریل میں، ہم نے احاطہ کیا: Python Exceptions، Traceback؛ کوشش کریں / سوائے / باقی / آخر میں کے ساتھ مستثنیات کو کیسے ہینڈل کریںبلاکس، کیسے بڑھائیں مستثنیات، اور آخر کار اپنی مرضی کے استثناء کیسے بنائیں۔
پڑھنے کا شکریہ!
مترجم اسے ایک غلط آپریشن کے طور پر دیکھتا ہے اور ZeroDivisionErrorاٹھاتا ہے، پروگرام میں خلل ڈالتا ہے، اور ٹریس بیک پرنٹ کرتا ہے۔
ہم واضح طور پر دیکھ سکتے ہیں کہ ZeroDivisionError وہ استثنا ہے جو اٹھایا گیا تھا۔ ہمیں بتانے کا یہ واقعی ازگر کا اپنا طریقہ ہے کہ کسی نمبر کو صفر سے تقسیم کرنا اچھا نہیں ہے۔ اگرچہ جاوا اسکرپٹ جیسی دوسری زبانوں میں، یہ کوئی غلطی نہیں ہے۔ اور python اس عمل کو سختی سے منع کرتا ہے۔
اس کے علاوہ، یہ جاننا بھی ضروری ہے کہ یہ صرف ایک استثنائی چیز ہے اور Python میں اس طرح کی بہت سی اشیاء شامل ہیں۔ ازگر کے تمام بلٹ ان استثناء کو دیکھنے کے لیے ازگر کی یہ آفیشل دستاویزات دیکھیں۔
ٹریس بیک کو سمجھنا
اس سے پہلے کہ ہم مستثنیات کو سنبھالیں، میرے خیال میں یہ سمجھنے میں مدد ملے گی کہ مستثنیات کی صورت میں اصل میں کیا ہوگا۔ کو ہینڈل نہیں کیا جاتا ہے اور Python ہماری غلطی کے بارے میں ہمیں مطلع کرنے کی پوری کوشش کیسے کرتا ہے۔
جب بھی Python کو کسی غلطی کا سامنا ہوتا ہے، یہ ایک استثناء پیدا کرتا ہے۔ اگر اس استثناء کو سنبھالا نہیں جاتا ہے، تو یہ کچھ معلومات پیدا کرتا ہے جسے Traceback کہتے ہیں۔ تو، اس ٹریس بیک میں کون سی معلومات شامل ہیں؟
اس پر مشتمل ہے:
- خرابی کا پیغام جو ہمیں بتاتا ہے کہ اس استثناء سے پہلے کیا ہوا تھا اٹھایا گیا ہے۔
- کوڈ کے مختلف لائن نمبرز جن کی وجہ سے یہ خرابی ہوئی۔ ایک خرابی فنکشن کالز کی ایک ترتیب کی وجہ سے ہو سکتی ہے جسے کال اسٹیک کہا جاتا ہے جس پر ہم بعد میں یہاں بات کریں گے۔
اگرچہ یہ ایکتھوڑا سا الجھا ہوا، ہم وعدہ کرتے ہیں کہ اگلی مثال ہماری سمجھ میں مزید روشنی ڈالے گی۔
اس ٹریس بیک کو یاد کریں جو اوپر 50 کو 0 سے تقسیم کرنے سے پرنٹ کیا گیا تھا، ہم دیکھ سکتے ہیں کہ ٹریس بیک میں درج ذیل معلومات شامل ہیں:
- فائل "": یہ ہمیں بتاتا ہے کہ یہ کوڈ کنسول ٹرمینل سے چلایا گیا تھا۔
- لائن 1: یہ ہمیں بتاتا ہے کہ اس لائن نمبر میں غلطی ہوئی ہے۔
- ZeroDivisionError: division by zero: یہ ہمیں بتاتا ہے کہ کس استثناء کو اٹھایا گیا اور اس کی وجہ کیا ہے۔
آئیے ایک اور مثال آزمائیں اور شاید دیکھیں کہ کال اسٹیک کیسا لگتا ہے۔ ایک ایڈیٹر کھولیں، نیچے کوڈ درج کریں اور بطور 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 ٹریس بیک کو پڑھنے کا بہترین طریقہ لے کر آیا، جو نیچے سے اوپر سے ہے۔ لہذا، آئیے اس حکمت کو استعمال کرتے ہوئے یہ سمجھنے کی کوشش کریں کہ یہ ٹریس بیک کیا پیش کرتا ہے۔
- سب سے نیچے، ہمیں وہ استثنا ملتا ہے جو اٹھایا گیا تھا اور کیوں اٹھایا گیا تھا۔ 5 اوپر منتقل ہونے پر، ہمیں فائل کا نام tracebackExp .py ملتا ہے جہاں یہ ایرر پیش آیا، وہ کمپیوٹیشن جس کی وجہ سے یہ ایرر ہوا compute = numb/div، فنکشن stack2، اور لنک نمبر لائن 6 جہاں یہ گنتی کی گئی تھی۔ .
- اوپر کی طرف بڑھتے ہوئے، ہم دیکھتے ہیں کہ ہمارا stack2 فنکشن ہے۔لائن نمبر 3 میں فنکشن stack1 میں بلایا گیا تھا۔
- سب سے اوپر کی طرف بڑھتے ہوئے، ہم دیکھتے ہیں کہ فنکشن stack1 کو لائن نمبر 11 میں بلایا گیا تھا۔ module > ہمیں بتاتا ہے کہ یہ وہی فائل ہے جس پر عمل کیا جا رہا ہے۔
عام ازگر استثناء
پائیتھن لائبریری بہت زیادہ بلٹ ان استثناء کی وضاحت کرتی ہے۔ آپ ازگر کی دستاویزات کو چیک کر سکتے ہیں یا بلٹ ان مقامی () فنکشن کو نیچے کے طور پر کال کر سکتے ہیں:
>>> 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 ملتا ہے کیونکہ ڈویژن آپریٹر (/) تاروں پر کام نہیں کرتا ہے۔
یہ جان کر آپ کو دلچسپی ہو سکتی ہے کہ Python کے برعکس، جاوا اسکرپٹ میں Type Coercion ہے جو بنیادی طور پر آپرینڈ کی ایک قسم کو دوسرے آپرینڈ کی قسم کے مساوی قدر میں تبدیل کرتا ہے جب آپرینڈزمختلف اقسام۔
#2) ValueError
یہ اس وقت اٹھایا جاتا ہے جب کسی آپریشن یا فنکشن کو ایسی دلیل موصول ہوتی ہے جس کی صحیح قسم ہوتی ہے لیکن ایک نامناسب قدر ہوتی ہے۔
مثال 2
اوپر مثال 1 میں ہمارے پروگرام پر غور کریں۔
اگر صارف '3a' جیسے ڈیویڈنڈ کے لیے ایک حروفِ عددی قدر ڈالتا ہے، تو ہمارا پروگرام بڑھ جائے گا۔ ValueError کی رعایت۔ اس کی وجہ یہ ہے کہ اگرچہ Python int() طریقہ کسی بھی نمبر یا سٹرنگ کو لے کر ایک عددی شے لوٹاتا ہے، اسٹرنگ ویلیو میں حروف یا کوئی غیر عددی قدر نہیں ہونی چاہیے۔
#3) AttributeError
یہ استثنیٰ کسی ایسے انتساب کو تفویض یا حوالہ دیتے وقت اٹھایا جاتا ہے جو موجود نہیں ہے۔
مثال 3
پروگرام پر غور کریں۔ نیچے یہ ایک عدد لیتا ہے اور Python ریاضی کے ماڈیول کا استعمال کرتے ہوئے اس کی مربع جڑ کی گنتی کرتا ہے
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 کا حوالہ دینے کی کوشش کر رہے تھے جو موجود نہیں ہے اور رعایت کی وجہ سے AttributeError اٹھایا جا رہا ہے۔ ہم میں سے اکثر اس قسم کی غلطی بہت کرتے ہیں۔ لہذا، آپ اکیلے نہیں ہیں۔
استثنیٰ کو آزمائیں سوائے
ایک پروگرامر کے طور پر، ایک چیز جس پر ہم میں سے زیادہ تر اپنا وقت صرف کریں گے وہ ہے ایک مضبوط کوڈ لکھنا۔لچکدار. کوڈ جو کچھ غلطیوں کی وجہ سے نہیں ٹوٹتا ہے۔ ازگر میں، ہم اپنے بیانات کو کوشش کریں – سوائے بیان کے اندر بند کر کے اسے حاصل کر سکتے ہیں۔
Try-except Statement کی مندرجہ ذیل ساخت ہے:
try: #your code goes here except """Specify exception type(s) here""": #handle exception here
آئیے کوڈ کو tracebackExp .py میں ایک try-except بیان کے اندر منسلک کریں۔
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_ value 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
ہم نے یہاں دیکھا کہ استثناء آخری بیان کے علاوہ استعمال کیا گیا تھا۔ . اس کی وجہ یہ ہے کہ Exception آبجیکٹ Exception کسی بھی استثناء سے میل کھاتا ہے۔ اس وجہ سے، یہ ہمیشہ آخری ہونا چاہیے، کیونکہ ایک کے میچ ہونے پر ازگر دوسرے استثنائی ہینڈلرز کو چیک کرنا بند کر دے گا۔
اوپر کوڈ میں، idx=5 ، اس لیے arr[idx ] بڑھے گا IndexError کیونکہ idx فہرست کی لمبائی سے زیادہ ہے arr
اس کے علاوہ، اس بات کا یقین نہیں ہے کہ آپ کی درخواست کی طرف سے کیا استثنا اٹھایا گیا ہے، عملدرآمد جاری رکھنے کے لئے کبھی بھی محفوظ نہیں ہے. اسی لیے ہمارے پاس کسی بھی غیر متوقع استثناء کو پکڑنے کے لیے Exception کی قسم ہے۔ پھر، ہم مطلع کرتے ہیںصارف اور اسی استثنیٰ کو بڑھا کر ایپلیکیشن میں خلل ڈالیں۔
دوسرے بیان کی کوشش کریں
یہ ایک اختیاری خصوصیت استثناء ہینڈلنگ کی ہے اور آپ کو اس کوڈ کو شامل کرنے کی اجازت دیتی ہے جسے آپ چاہتے ہیں۔ چلائیں جب کوئی غلطی نہیں ہوئی ہے۔ اگر کوئی خرابی پیش آتی ہے، تو یہ else-بلاک نہیں چلے گا۔
پیتھون کوڈ کی مثال پر غور کریں، اپنا ایڈیٹر کھولیں اور کوڈ کو 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) break0 کے طور پر محفوظ کریں۔>ہم صارف سے ان پٹ حاصل کرتے ہیں اور اسے 1 کو تقسیم کرنے کے لیے استعمال کرتے ہیں۔ ہمارے یہاں دو ممکنہ مستثنیات ہیں، ایک غلط صارف کا ان پٹ جو ValueError اور zero(0) کا سبب بنے گا۔ زیرو ڈویژن ایرر ۔ ہمارا سوائے اسٹیٹمنٹ ان غلطیوں کو سنبھالتا ہے۔
اب، ہم قدر کی قدر پرنٹ کرنا چاہتے ہیں۔ ہمارا else-block اس بات کو یقینی بناتا ہے کہ یہ صرف اس صورت میں پرنٹ کیا گیا ہے جب ہماری کوشش بلاک بغیر کسی غلطی کے عمل میں آتی ہے۔ یہ اہم ہے کیونکہ اگر ہمارے ٹرائی بلاک میں کوئی خرابی واقع ہوتی ہے، تو قدر کی وضاحت نہیں کی جائے گی۔ لہذا، اس تک رسائی ایک اور خرابی کو جنم دے گی۔
اوپر کوڈ کو Python elseTry.py کے ساتھ چلائیں
اوپر کا آؤٹ پٹ ظاہر کرتا ہے کہ پہلے ان پٹ کے لیے، ہم نے 0 ٹائپ کیا اور ENTER دبایا۔ چونکہ ہمارے تقسیم کار نے 0 حاصل کیا، 1/divisor نے zeroDivisionError اٹھایا۔ ہمارا دوسرا ان پٹ k تھا جو int () کے لیے غلط ہے، اس لیے استثناء ValueError اٹھایا گیا ہے۔
لیکن ہمارا آخری ان پٹ 9 تھا جو درست ہے اور بطور ایک نتیجہ، ہمیں " value " کی قدر 0.1111111111111111
آخر میں آزمائیںبیان
یہ استثنائی ہینڈلنگ کی ایک اختیاری خصوصیت بھی ہے اور ہمیشہ اس سے کوئی فرق نہیں پڑتا ہے کہ استثنائی ہینڈلرز میں کیا ہوتا ہے۔
یعنی:
- 5
لہذا، اگر ہمارے پاس ایک کوڈ ہے جسے ہم تمام حالات میں چلانا چاہتے ہیں، آخر میں بلاک ہمارا آدمی ہے۔ یہ بلاک زیادہ تر کلین اپس جیسے فائلوں کو بند کرنے کے لیے استعمال ہوتا ہے۔
نیچے دیے گئے ازگر کوڈ پر غور کریں
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 کا ذیلی طبقہ ہے۔
یہ بنیادی طور پر یہ کہتا ہے کہ ہم حوالہ دینے کی کوشش کر رہے ہیں۔ دی