Vivasoft-logo

Exception Handling in Python

কোড করতে গিয়ে অসঙ্গত অপারেশন অথবা ভুল ইনপুট ইত্যাদি নানা কারণে এক্সসেপশন / এরর আসতেই পারে। পাইথন নিজে থেকে এগুলো সল্ভ করে দিবে না। কোন একটা লাইনের এক্সেপশন আমাদের পুরো প্রোগ্রাম কে বন্ধ করে দিতে পারে। সেক্ষেত্রে, সবচেয়ে ভালো উপায় হচ্ছে সতর্কতার সাথে , সেই সব এরর / এক্সেপশন হ্যান্ডেল করার কোড লিখে রাখা। তবে , শুধু মাত্র যেসব জায়গায় এরর / এক্সেপশন আসতে পারে সেইসব জায়গায়। তাহলে , আমাদের পুরো প্রোগ্রাম বন্ধ ও হবে না এবং আমরা আমাদের ভুলগুলো ও সাথে সাথে টার্মিনাল থেকে দেখে নিতে পারবো।

Syntax

try:
  # statement_1
  # statement_2
  …
  # statement_n
except:
  # execute if error occured in try block
 

যেই কোড গুলো ভুল হবার সম্ভাবনা রয়েছে সেগুলো আমরা try block এ লিখবো। ভুল হলে , প্রোগ্রামটি বন্ধ হবার পরিবর্তে পাইথনকে কি করতে হবে , সেই সমস্ত ইন্সট্রাকশন except এ লিখে দিবো। try block এ যদি কোনো এক্সেপশন / এরর না থাকে , তাহলে কখনোই except block কাজ করবে না। try block এ একটি ভুল হলেই except block কাজ করবে ।

try:
  print(2 + 2)
  x = 4
  print( x / 10)
  print("Last Line")
except:
  print("Error Occured")


4
0.4
Last Line
 

উপরের উদাহরণে try block এ কোনো এক্সেপশন / এরর নেই , এজন্য except block এর লিখা প্রিন্ট হয় নি।

এখন যদি আমরা একটি ভুল করি —

try:
  print(2 + 2)
  x = 4
  print( x / 0)
  print("Last Line")
except:
  print("Error Occured")


4
Error Occured
 

তাহলে দেখা যাচ্ছে 3 no. লাইন পর্যন্ত try block এ কোন সমস্যা ছিল না বলেই , try block এর 3 no. লাইন পর্যন্ত এক্সিকিউট হয়েছে। যখন 4 no. লাইনে আমরা 0 দিয়ে ভাগ দিতে চেয়েছি যেটা আসলে একটা এরর , এরজন্য এরপর থেকে আর কোন লাইন try block এ এক্সিকিউট না হয়ে , সরাসরি except এ চলে গিয়ে “ Error Occured ” (যেটা আমরা এ লিখেছি ) প্রিন্ট করেছে।

তবে , একটি সমস্যা আছে , আমরা টার্মিনাল দেখে বলতে পারবো না , আসলে কি ভুল হয়েছে , এজন্য এরর মেসেজটি স্পেসিফিকভাবে লিখা ভালো।

try:

print(2 + 2)

x = 4

print( x / 0)

print("Last Line")

except:

print("Error ! Can not divided by zero")


4

Error ! Can not divided by zero
 

বেশ ! কিন্তু , সবসময় এরর / এক্সসেপশন আমাদের জানার মধ্যে নাও থাকতে পারে। যেকোনো এক্সেপশন হলে কি করতে হবে , সেই মেসেজ এর দায়ভার আমরা পাইথনের উপর ছেড়ে দিতে পারি।

try:

print(2 + 2)

x = 4

print( x / 0)

print("Last Line")

except Exception as e:

print(f"Error ! {e}")
 

Exception keyword দিয়ে এক্সেপশন ধরে এর e variable এর মধ্যে স্টোর করলাম। যার ফলে , যেকোনো এক্সেপশন হোক না কেন , আমরা সেই দায়িত্ব পাইথনের হাতে ছেড়ে দিলাম। এবং পাইথন ই এরর মেসেজ জেনারেট করে দিবে।

আরেকটি বিষয় থেকে যায় সেটা হলো , ঢালাওভাবে সব এক্সেপশন হ্যান্ডেল করাটা ভালো অভ্যাস না। স্পেসিফিক এক্সসেপশন-ই আমাদের হ্যান্ডেল করা উচিত।

try:

print(2 + 2)

x = 4

print( x / 0)

print("Last Line")

except ZeroDivisionError as e:

print(f"Error : {e}")
 

সো , এভাবে এক্সেপশন গুলো ধরলে , কোডের রিডিবিলিটি ভালো থাকে।

আমরা চাইলে একটি try block এর জন্য মাল্টিপল except block রাখতে পারি। এখানে একটি বিষয় লক্ষ্যণীয় , অনেকগুলা except block থাকলেও মাত্র একটা except block কাজ করবে , এবং এর মধ্যে যেই এক্সেপশন আগে ঘটবে , তার জন্য লেখা except block কাজ করবে।

try:

print(2 + 2)

x = 4

print( y / 0)

print("Last Line")

except ZeroDivisionError as e:

print(f"Error : {e}")

except NameError as e:

print(f"Error : {e}")
 

দেখেই বুঝতে পেরেছেন , 4 no. লাইনে ভুল করেছি। কিন্তু এখানে ভুল করেছি দুইটা-

  • y variable টি আগে কোথাও ডিফাইন করা ছাড়াই এখানে ব্যবহার করছি
  • y কে 0 দ্বারা ভাগ করছি

আবার লিখার জন্য লিখেছি আগে এবং লিখেছি পরে। কিন্তু পাইথন কোড এক্সিকিউট করার সময় আগে y কে পাবে , তাই NameError এক্সসেপশন ব্লকটাই কাজ করবে ।

4

Error : name 'y' is not defined
 

এই try-except ব্লক এর সাথে আরেকটা block পাইথন আমাদেরকে অতিরিক্ত দিয়ে থাকে। সেটা হচ্ছে finally block। এই block এর কাজ হচ্ছে , যে try / except যেটাই কাজ করুক না কেন , তার পরে সবার শেষে finally block কাজ করবেই।

try:

print(2 + 2)

x = 4

print( y / 0)

except ZeroDivisionError as e:

print(f"Error : {e}")

except NameError as e:

print(f"Error : {e}")

finally:

print("I am 'finally' working…")


4

Error : name 'y' is not defined

I am 'finally' working…
 

ধরেন , try block এ কোন ধরণের এরর / এক্সেপশন হয় নি , এবং এটার জন্য , আমরা try block এর কোন ডাটা এর উপর কোন কাজ করতে চাচ্ছি। সেটা করতে গেলে , পাইথন আমাদের কে আরো একটা block দিয়ে থাকে। সেটা হচ্ছে else block। এটা কিন্তু if-else এর else না।

try:

print(2 + 2)

x = 4

y = x / 2

except ZeroDivisionError as e:

print(f"Error : {e}")

except NameError as e:

print(f"Error : {e}")

else:

# working if try block is completely error free

print(f"Value of y is {y}")

finally:

print("I am 'finally' working…")


4

Value of y is 2.0

I am 'finally' working…
 

else block কাজ করতে হলে , try block এ কোন ধরণের এক্সেপশন থাকা যাবে না।

উদাহরন

উদাহরণ ১

try ভিতর কোন statement ভুল হলে except ভিতর যে statement গুলো থাকবে তা রান হবে কিন্তু যদি try ভিতর সব statement ঠিক থাকে তবে except ভিতর কোন statement কাজ করবে নাহ । একটি   উদাহরণ দেখা যাক

print('One')
print('Two')
try:
print(10/0)
except ZeroDivisionError:
print("Exception passed")
print('Four')
print('Five')


One
Two
Exception passed
Four
Five
 

উদাহরণ ২

আমাদের অনেক সময় try statement আলাদা আলাদা error জন্য আলাদা আলাদা error দেখানোর জন্য multiple except blocks এর ব্যবহার করে থাকি –

try:
x=int(input("Enter First Number: "))
y=int(input("Enter Second Number: "))
print(x/y)
except ZeroDivisionError:
print("Can't Divide with Zero")
except ValueError:
print("please provide int value only")


Enter First Number: 10
Enter Second Number: 2
5.0

Enter First Number: 23
Enter Second Number: 0
Can't Divide with Zero

Enter First Number: 12
Enter Second Number: zero
please provide int value only
 

উদাহরণ ৩

আলাদা আলাদা  multiple exception না লিখে আমরা  এক লাইনে except করার জন্য আমাদের কে সাধারণত validation error কে টাপল এ মধ্যে রেখে চেক করতে হবে  –

try:
x=int(input("Enter First Number: "))
y=int(input("Enter Second Number: "))
print(x/y)
except(ZeroDivisionError,ValueError)as e:
print("Please Provide valid numbers only and problem is: ", e)


Enter First Number: 10
Enter Second Number: one
Please Provide valid numbers only and problem is: invalid literal forint() with base 10: 'one'

Enter First Number: 10
Enter Second Number: 0
Please Provide valid numbers only and problem is: division by zero
 

উদাহরণ ৪

আমাদের অনেক সময় exist validation error check করে কোন ইরর না ধরতে পারলে তখন আমরা তা default exception দিয়ে চেক করে থাকি –

try:
x=int(input("Enter First Number: "))
y=int(input("Enter Second Number: "))
print(x/y)
except ZeroDivisionError:
print("ZeroDivisionError: Can't divide with zero")
except:
print("Default Except: Please provide valid input only")


Enter First Number: 10
Enter Second Number: 0
ZeroDivisionError: Can't divide with zero

Enter First Number: 10
Enter Second Number: zero
Default Except: Please provide valid input only
 

উদাহরণ ৫

আমাদের try-except এ finally নামে আর একটা keyword থাকে যা দিয়ে আমাদের try-except যেকোন statement ঠিক execute হোক না কেন finally  এর ভিতর যে statement থাকবে তা অবশ্যই রান করবে ।

try:
x=int(input("Enter First Number: "))
y=int(input("Enter Second Number: "))
print(x/y)
except ZeroDivisionError:
print("ZeroDivisionError: Can't divide with zero")
finally:
print('Finishing up.')


Enter First Number: 10
Enter Second Number: 20
0.5
Finishing up.

Enter First Number: 10
Enter Second Number: 0
ZeroDivisionError: Can't divide with zero
Finishing up.
 

এসো নিজে করি

অনুশীলনঃ

  • এমন একটি টেক্সট ফাইল ওপেন করার চেষ্টা করুন , যেটি আপনার ডিস্কে নেই , এবং যথাযথ এরর প্রিন্ট করে দেখান।
  • একটি ফাংশন দুইটি প্যারামিটার নেয় , এবং এর কাজ হচ্ছে ভাগফল বের করে দেয়া। ফাংশনটি এমনভাবে লিখুন যেন কখনই এরর না দেয়। (sample input: a=10,b=5 | a=”a”,b=10 | a= 10 , b= 0)
  • আপনাকে একটি অ্যারে দেওয়া হলো । আপনার কাজ হচ্ছে একটি ইনফিনিটি লুপ চালিয়ে অ্যারের সব ভ্যালু প্রিন্ট করতে কিন্তু অই ইনফিনিটি লুপ থেকে বের হবার জন্য আপনি কোন কন্ডিশনাল statement ব্যবহার করতে পারবেন নাহ ।  আবার কোড কোন ভুল দেখাবে নাহ ।
  • দুই টি ইনপুট  নিবেন এবং টার্মিনাল থেকে ইনপুট নেবার যত ধরনের লজিকাল এরর খাওয়া যায় সব গুলো এরর গুলো প্রিন্ট করবেন এবং লাস্ট বেলায় সঠিক ইনপুট নিয়ে তাদের ভাগফল দেখাবেন । যত বেশি এরর handle করতে পারবেন আপনার পয়েন্ট তত বেশি ।
  • একটি কোড লিখবেন যা দিয়ে একটি ফাইল open হবে । এখন যদি আমাদের ডেস্ক অই ফাইল থাকে তবে তা ওপেন হবে আর না থাকলে ওপেন হবে নাহ । কিন্তু আমাদের কোডের শেষবেলায় দায়িত্ব অই ফাইল টি close করা । আপনারা এই কোড টি try-exception মাধ্যমে করার চেষ্টা করবেন ।

ইন্টারভিউ প্রশ্নোত্তর

গুরুত্বপূর্ন প্রশ্নসমুহ

  • কোন keyword দিয়ে আমরা এরর গুলো দেখতে পারি ?
  • কোন ব্লক দিয়ে আমরা ঝামেলাপুর্ন কোড হ্যান্ডেল করি ?
  • এরর হ্যান্ডেল করা কেন জরুরী ?
  • পাইথন এ কিছু built-in-exceptions সম্পর্কে বলেন ।
  • পাইথন এ raising an error এবং throwing an exception পার্থক্য কি ?