আমরা এই চ্যাপ্টারে লিস্ট ও ডিকশনারি কম্প্রিহেনশন সম্পর্কে জানার চেষ্টা করব। প্রথমে লিস্ট কম্প্রিহেনশন বিষয়টা বোঝার জন্য একটা উদাহরণ দিয়ে দেখা যাক।
ধরি, num_list
একটি পাইথন লিস্ট যেখানে ১-১০ সংখ্যাগুলো আছে।
num_list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
এখন আপনাকে যদি বলা হয় পাইথনে একটি কোড লিখতে যেটা কিনা সংখ্যাগুলো থেকে শুধু জোড় সংখ্যাগুলো নিয়ে আরেকটি লিস্ট তৈরি করতে এবং আপনার যদি লিস্ট কম্প্রিহেনশন সম্পর্কে ধারণা না থাকে তাহলে আপনি অবশ্যই এভাবে লিখবেন,
even_num_list = []
for num in num_list:
if num % 2 == 0:
even_num_list.append(num)
print (even_num_list)
[2, 4, 6, 8, 10]
কিন্তু আপনার যদি এ ব্যাপারে ভাল ধারণা থাকে তাহলে আপনি কোডটি এক লাইনেই লিখতে পারবেন।
even_num_list = [even_num for even_num in num_list if even_num % 2 == 0]
print (even_num_list)
চমৎকার, তাই না?
এটাই পাইথনের মজা, প্রতিটা ল্যাঙ্গুয়েজের আলাদা কিছু বৈশিষ্ট্য থাকে যেটা তাকে আলাদা করে তোলে। লিস্ট কম্প্রিহেনশন পাইথনের ক্ষেত্রে এরকম অন্যতম একটি বৈশিষ্ট্য।
কিন্তু এটা করলাম কীভাবে? একটু ভিজুয়ালাইজ করার চেষ্টা করি!
একটা লিস্ট / ইটার্যাবল থেকে আরেকটা লিস্টে রূপান্তর করার একটা পদ্ধতি।
পাইথনের লিস্ট কম্প্রিহেনশন জিনিসটা বেশ মজার কিন্তু একই সাথে পাইথন বিগিনার দের জন্য একটু ঝামেলাকর। সেটা দূর করার জন্যই এই চ্যাপ্টার।
অনেকসময় অন্যের করা লিস্ট কম্প্রিহেনশনের কোডগুলো বোঝা কঠিন হয়ে যায়। সেক্ষেত্রে আপনি চাইলে ভেঙ্গেও লিখতে পারেন।
even_num_list = [
num
for num in num_list
if num % 2 == 0
]
print(even_num_list)
চলুন আরও কিছু উদাহরণ দেখা যাক।
নেস্টেড লুপের লিস্ট কম্প্রিহেনশন দেখানোর জন্য 2D ম্যাট্রিক্সের উদাহরণ দেখানোর উপরে কিছু নাই। মনে করুন, আপনার একটা Matrix / 2D Array আছে, সেটাকে আপনি ফ্ল্যাটেন বা 1D করতে চাচ্ছেন, এই সমস্যাটা আমরা এভাবে সমাধান করতে পারি,
matrix_1d = []
matrix_2d = [[1, 2, 3],
[4, 5, 6]]
for row in matrix_2d:
for num in row:
matrix_1d.append(num)
print(matrix_1d)
[1, 2, 3, 4, 5, 6]
লিস্ট কম্প্রিহেনশন ব্যবহার করে,
matrix_2d = [[1, 2, 3],
[4, 5, 6]]
matrix_1d = [num for row in matrix_2d for num in row]
[1, 2, 3, 4, 5, 6]
আগের মতই কপি পেস্ট করলাম, প্রথমে যেটা অ্যাড করব সেটা লিখলাম তারপর টপ লেভেল লুপ এবং অবশেষে নেস্টেড লুপ লিখে কোডটি কম্প্লিট করলাম।
ধরুন, আপনি matrix_1d
তে প্রতিটা এলিমেন্টের বর্গ বা স্কয়ার ভ্যালু নিতে চাচ্ছেন, তাহলে কোড হবে এমন,
matrix_1d = [num**2 for row in matrix_2d for num in row]
[1, 4, 9, 16, 25, 36]
সাধারণ নিয়মে,
vowels = 'aeiou'
sentence = 'I am awesome!'
filtered_letters = []
for letter in sentence:
if letter not in vowels:
filtered_letters.append(letter)
print(''.join(filtered_letters))
I m wsm!
লিস্ট কম্প্রিহেনশন ব্যবহার করে
vowels = 'aeiou'
sentence = 'I am awesome'
filtered_sentence = ''.join([letter for letter in sentence if letter not in vowels])
print(filtered_sentence)
I m wsm
এটা লিস্ট কম্প্রিহেনশনের মতই, শুধু লিস্টের বদলে ডিকশনারি ডেটা স্ট্রাকচার ব্যবহার করব। আমরা যদি দুইটা লিস্ট থেকে একটা ডিকশনারি বানাতে চাই, যেখানে প্রথমটি Key
এবং পরেরটি Value
তাহলে সাধারণ নিয়মে এভাবে কোড লিখব,
fruit_ranking = [1, 2, 3]
fruit_name = ['Mango', 'Pineapple', 'Watermelon']
fruit_rank_dict = {}
for i in range(len(fruit_ranking)):
fruit_rank_dict[fruit_ranking[i]] = fruit_name[i]
print(fruit_rank_dict)
{1: 'Mango', 2: 'Pineapple', 3: 'Watermelon'}
ডিকশনারি কম্প্রিহেনশন ব্যবহার করে,
fruit_ranking = [1, 2, 3]
fruit = ['Mango', 'Pineapple', 'Watermelon']
fruit_ranking_dict = { fruit_ranking[i] : fruit[i] for i in range(len(fruit_ranking)) }
print(fruit_ranking_dict)
{1: 'Mango', 2: 'Pineapple', 3: 'Watermelon'}
কোন কোন ক্ষেত্রে লিস্ট বা ডিকশনারি কম্প্রিহেনশন ব্যবহার করা শুধু সুবিধাজনক তা-ই নয়, সিম্পল এক্সপ্রেশনে এটা ফর লুপের চেয়েও ফাস্ট। কম্পলেক্স এক্সপ্রেশনে ফর লুপ আর লিস্ট কম্প্রিহেনশনের পারফর্মেন্স প্রায় একই।
সংকলন: মানস