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