
Please support if you like my work by payment through upi: sinhamit@icici or payment by bank
account name: Amit Kumar Sinha,
account number: 2646728782
IFSC code: KKBK0005660
SWIFT: KKBKINBB
Comprehensions and Ternary Expressions in Category: पाइथन by amit
🕙 Posted on 2023-08-27 at 08:16:10
सूची (list), डिक्शनरी और सेट कॉम्प्रिहेंशन
आपने PHP और JavaScript जैसी अन्य प्रोग्रामिंग भाषाओं में ?: (टर्नरी ऑपरेटर) के बारे में सुना होगा। हालाँकि, पायथन में टर्नरी ऑपरेटर अन्य सभी ऑपरेशनों के बीच सबसे कम प्राथमिकता वाला है, और इसका एक उदाहरण नीचे दिखाया गया है। लेकिन, पायथन में लिस्ट कॉम्प्रिहेंशन और डिक्शनरी कॉम्प्रिहेंशन का अक्सर उपयोग किया जाता है, और ये बहुत महत्वपूर्ण हैं। टर्नरी ऑपरेटर और लिस्ट/
टर्नरी ऑपरेटर
उदाहरण 1:
x, y = 30, 20
result = x if x < y else y
print( result ) # Outputs 20
आप देख सकते हैं कि उपरोक्त उदाहरण को जब if else ब्लॉक में लिखा जाता है, तो उपरोक्त कोड की तीन पंक्तियाँ, छह पंक्तियों में लिखी जाती है, वह भी इंडेंटेशन के साथ। प्रोग्रामिंग भाषाओं में, एक अभिव्यक्ति का आउटपुट आम तौर पर एक चर नाम को सौंपा जाता है, ताकि इसे पृष्ठभूमि या बैक-एंड प्रक्रियाओं में आगे उपयोग किया जा सके। print() अंतर्निहित फ़ंक्शन का उपयोग करके या अन्य मॉड्यूल का उपयोग करके परिणाम प्रदर्शित करना दुर्लभ है और पूरे प्रोग्राम का अंतिम परिणाम है।
उदाहरण 2:
x, y = 30, 20if x < y:
result = xelse:
result = y
print( result ) # Outputs 20
कॉम्प्रिहेंशन्स Comprehensions
आप पहले ही for लूप के विभिन्न उदाहरण देख चुके हैं। यहां आपको ध्यान देना चाहिए कि सभी सूची, डिक्शनरी और सेट कॉम्प्रिहेंशन for लूप के संक्षिप्त रूप हैं, और इसलिए, उन्हें for लूप के ब्लॉक कोड में भी लिखा जा सकता है। लेकिन, एक for लूप ब्लॉक में कई स्टेटमेंट (कोड की पंक्तियाँ) हो सकते हैं, और इसलिए for लूप का एक जटिल (व्यापक) ब्लॉक कोड लिस्ट/if else कोड के ब्लॉक और टर्नरी एक्सप्रेशन (ऊपर बताया गया) के बारे में भी यही सादृश्य सत्य है।
जब आपके डेटा में बड़ी मात्रा में फ़्लोट होते हैं (अर्थात, किसी सूची में आइटम/
सूची कॉम्प्रिहेंशन्स
कॉम्प्रिहेंशन्स परिवर्तनशील अनुक्रम डेटा-प्रकारों के लिए है, अर्थात सूची, डिक्शनरी और सेट। सूची (list) कॉम्प्रिहेंशन का सिंटैक्स इस प्रकार है:
variable_name = [expression for item in iterable]
उदाहरण 3: निम्नलिखित उदाहरण में, temps मूल सूची डेटा-प्रकार (पुनरावर्तनीय) है, और वह भी वर्गाकार कोष्ठकों की एक जोड़ी के अंदर है, ताकि for लूप इससे प्रत्येक आइटम/
temps = [351, 344, 340, 445] # डेटा-भंडारण को बचाने के लिए दशमलव का उपयोग न (कम) करें
my_temps = [temp / 10 for temp in temps] # list comprehension
print(my_temps, type(my_temps))
उदाहरण 4:
temps = [351, 344, 340, 445]
new_temps = []for temp in temps:
new_temps.append(temp / 10)
print(new_temps, type(new_temps)) # आउटपुट ऊपर जैसा ही है
Caution: आपको ध्यान देना चाहिए कि सूची कॉम्प्रिहेंशन सिंटैक्स के अंदर परिभाषित किया गया एक चर नाम (उदाहरण के लिए, [my_var for my_var in my_list] अभिव्यक्ति के अंदर my_var) इसके बाहर से पहुंच योग्य नहीं है। अर्थात्, यह सूची कॉम्प्रिहेंशन के लिए स्थानीय (local) है। हालाँकि, for लूप के अंदर परिभाषित एक चर नाम (उदाहरण के लिए, निम्नलिखित for लूप के ब्लॉक कोड में item) लूप के बाहर (नीचे) उपलब्ध और पहुंच योग्य है।
for item in [1,2,3,4,5]:
print( item ) # लूप के अंदर
print( item ) # लूप के बाहर, पुनरावर्तनीय (iterable) के अंतिम आइटम को आउटपुट करता है।
2
3
4
5
5
इसलिए, किसी अभिव्यक्ति या कोड के ब्लॉक के अंदर घोषित इस प्रकार के चर का उपयोग करते समय आपको सावधान रहना चाहिए। चर दायरे (variable scope) को बाद के पृष्ठों में समझाया जाएगा। सूची कॉम्प्रिहेंशन (विस्तारित) का सिंटैक्स इस प्रकार है:
variable_name = [expression for item in iterable if item condition literal]
उदाहरण 5:निम्नलिखित उदाहरण में, temps मूल सूची है, इसमें पूर्णांक आइटम हैं। temps सूची का प्रत्येक तत्व, temp पर >=(एक तुलना ऑपरेटर) द्वारा एक शर्त की जाँच की जाती है। जब प्रत्येक तत्व पर शर्त (condition) का मूल्यांकन False किया जाता है, तो मूल सूची का संबंधित आइटम सूची कॉम्प्रिहेंशन्स की अभिव्यक्ति के लिए पारित (pass) नहीं किया जाता है। इसके बाद, सशर्त अभिव्यक्ति को आगे 10 से विभाजित किया गया है। और अंत में temp नए वेरिएबल नाम temp_result में जोड़ा गया है।
temps = [351, 344, -999, 340, 445] # सूची में कुछ अमान्य डेटा
temp_result = [temp / 10 for temp in temps if temp >= -273.0]
print(temp_result)
सूची कॉम्प्रिहेंशन में कई भाग होते हैं, इससे पहले कि इसे एक चर नाम को निर्दिष्ट किया जाए या सीधे print() फ़ंक्शन के अंदर मूल्यांकन (evaluate) किया जाए। जब शर्त for लूप से पहले होता है, तो पहले मूल सूची के प्रत्येक आइटम की शर्त (condition) से तुलना की जाएगी। जब शर्त का मूल्यांकन False होता है, तो else ब्लॉक का आउटपुट, सूची कॉम्प्रिहेंशन्स की अभिव्यक्ति (expression) को पारित कर किया जाएगा, अन्यथा सूची का मूल आइटम अभिव्यक्ति को पारित किया जाएगा।
variable_name = [expression if item condition literal else alternate_item for item in iterable]
उदाहरण 6:
temps = [351, 344, -999, 340, 445] # सूची में कुछ नकारात्मक डेटा
print( [temp/10 if temp > 0 else 0 for temp in temps] )
उदाहरण 5 में, आप देख सकते हैं कि (तीसरे आइटम का) नकारात्मक मान परिणामी सूची (अंतिम आउटपुट) में नहीं है, जबकि उदाहरण 6 में,0(तीसरे आइटम का मूल्य, elseपारित होने के बाद) मूल सूची के नकारात्मक आइटम को प्रतिस्थापित करता है।
उदाहरण 7: निम्नलिखित उदाहरण में, आप मूल सूची से सम संख्याओं की सूची या विषम संख्याओं की सूची बना सकते हैं यदि आप == (बराबर) ऑपरेटर को != (बराबर नहीं) ऑपरेटर से बदलते हैं। सूची कॉम्प्रिहेंशन की अवधारणा को ऊपर समझाया गया है।
my_numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
my_list = [num for num in my_numbers if num % 2 == 0]
print( my_list ) # आउटपुट [2, 4, 6, 8, 10] है।
उदाहरण 8:
my_numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
my_list = [] # खाली (empty) सूचीfor num in my_numbers:
if num % 2 == 0:
my_list.append(num)
print( my_list ) # आउटपुट [2, 4, 6, 8, 10] है।
स्ट्रिंग पर सूची कॉम्प्रिहेंशन
उदाहरण 9: यह सरल सूची कॉम्प्रिहेंशन स्वयं-व्याख्यात्मक है। आप निम्नलिखित कोड के पारंपरिक for लूप को स्वयं लिख सकते हैं।
my_str = "Hello World"
items = [letter for letter in my_str]
print(items)
अधिक जटिल सूची कॉम्प्रिहेंशन्स
उदाहरण 10:आप निम्नलिखित उदाहरण में [1, 2, 3, 4, 5, 6] (एक सूची शाब्दिक) के स्थान पर range() बिल्ट-इन फ़ंक्शन का उपयोग कर सकते हैं। नीचे वर्णित तीनों उदाहरणों के आउटपुट में समान है (उदाहरण 12 के नीचे दिखाया गया है)। निम्नलिखित तीन उदाहरणों में, स्ट्रिंग शाब्दिक 'abcdef' में प्रत्येक अक्षर (नेस्टेड टुपल में पहला आइटम) के लिए, दूसरी सूची शाब्दिक में, प्रत्येक नामित संख्या (या आप अन्य डेटा-प्रकार शाब्दिक को रख सकते हैं) नेस्टेड टपल के दूसरे आइटम के रूप में निर्दिष्ट किया गया है।
my_list = [(letter, num) for letter in 'abcdef' for num in [1, 2, 3, 4, 5, 6]]
print( my_list ) # आउटपुट नीचे दिखाया गया है:
उदाहरण 11: range() अंतर्निहित फ़ंक्शन को अगले पृष्ठ में समझाया गया है।
my_list = [(letter, num) for letter in 'abcdef' for num in range(6)]
print( my_list ) # आउटपुट नीचे दिखाया गया है:
उदाहरण 12:
my_list = []for letter in 'abcdef':
for num in [1, 2, 3, 4, 5, 6]:
my_list.append((letter, num))
print( my_list ) # आउटपुट नीचे दिखाया गया है:
डिक्शनरी कॉम्प्रिहेंशन्स
उदाहरण 13:हालांकि निम्नलिखित उदाहरण लंबा है, यहां नीचे दिखाया गया है कि एक डिक्शनरी कॉम्प्रिहेंशन zip()अंतर्निहित फ़ंक्शन के साथ या नेस्टेड टुपल्स की एक सूची/
roman_num = ['i', 'ii', 'iii', 'iv', 'v', 'vi']
english_num = ['one', 'two', 'three', 'four', 'five', 'six']
print( zip( roman_num, english_num ) ) # आउटपुट <zip object at 0x000001959
print( list(zip( roman_num, english_num )) ) # टुपल्स की एक सूची आउटपुट करता है
print( tuple(zip( roman_num, english_num )) ) # टुपल्स का एक टुपल आउटपुट करता है
print( dict(zip( roman_num, english_num )) ) # roman_num और english_num के संबंधित आइटम को कुंजी:मूल्य जोड़ी के रूप में, एक डिक्शनरी आउटपुट करता है।
my_dict = {} # खाली (empty) डिक्शनरीfor rom_num, eng_num in zip( roman_num, english_num ):
my_dict[rom_num] = eng_num
print( my_dict ) # rom_num: eng_num कुंजी:मान युग्म के रूप में एक डिक्शनरी आउटपुट करता है। आपको निम्नलिखित डिक्शनरी कॉम्प्रिहेंशन में इन स्थानीय चर का उपयोग नहीं करना चाहिए, अन्यथा आपको त्रुटि या अप्रत्याशित परिणाम मिलेगा!
new_dict = { r_num: e_num for r_num, e_num in zip( roman_num, english_num ) }
print( new_dict ) # r_num: e_num कुंजी:मान युग्म के रूप में एक डिक्शनरी आउटपुट करता है।
[('i', 'one'), ('ii', 'two'), ('iii', 'three'), ('iv', 'four'), ('v', 'five'), ('vi', 'six')]
(('i', 'one'), ('ii', 'two'), ('iii', 'three'), ('iv', 'four'), ('v', 'five'), ('vi', 'six'))
{'i': 'one', 'ii': 'two', 'iii': 'three', 'iv': 'four', 'v': 'five', 'vi': 'six'}
{'i': 'one', 'ii': 'two', 'iii': 'three', 'iv': 'four', 'v': 'five', 'vi': 'six'}
{'i': 'one', 'ii': 'two', 'iii': 'three', 'iv': 'four', 'v': 'five', 'vi': 'six'}
उदाहरण 14: निम्नलिखित उदाहरण में, आप डिक्शनरी कॉम्प्रिहेंशन के अंदर सशर्त अभिव्यक्ति का उपयोग कर सकते हैं, जैसा कि सूची कॉम्प्रिहेंशन्स के लिए ऊपर बताया गया है। जिन आइटम्स का मूल्यांकन False किया जाता है, डिक्शनरी कॉम्प्रिहेंशन शाब्दिक के आउटपुट में नहीं जोड़ा जाएगा।
roman_num = ['i', 'ii', 'iii', 'iv', 'v', 'vi']
english_num = ['one', 'two', 'three', 'four', 'five', 'six']
new_dict = {r_num: e_num for r_num, e_num in zip(roman_num, english_num) if r_num != 'iv'}
print(new_dict)
उदाहरण 15: निम्नलिखित उदाहरण में, आप उसी प्रकार का सिंटैक्स देख सकते हैं (जिसे विस्तारित सूची कॉम्प्रिहेंशन्स के लिए ऊपर समझाया गया है)। जब डिक्शनरी शाब्दिक का कोई भी आइटम (कुंजी:मूल्य युग्म) if शर्त को पूरा नहीं करता है, तो else कोड के ब्लॉक को डिक्शनरी कॉम्प्रिहेंशन के एक आइटम के रूप में पारित किया जाएगा। निम्नलिखित उदाहरण के नीचे वर्णित आउटपुट में तीसरा आइटम देखें।
roman_num = ['i', 'ii', 'iii', 'iv', 'v', 'vi']
english_num = ['one', 'two', 'three', 'four', 'five', 'six']
new_dict = {r_num: e_num if r_num != 'iv' else (4,'xyz') for r_num, e_num in zip(roman_num, english_num)}
print(new_dict)
सेट कॉम्प्रिहेंशन्स
उदाहरण 16: आप किसी सूची या टपल डेटा-प्रकार को set() अंतर्निहित फ़ंक्शन का उपयोग करके सेट डेटा-प्रकार शाब्दिक रूप से परिवर्तित कर सकते हैं। उदाहरण के लिए, set( [1, 2, 3, 1, 2, 3, 4, 5, 6, 4, 5, 6] ) (किसी सूची को सेट में टाइप-कास्ट करना) या set( (1, 2, 3, 1, 2, 3, 4, 5, 6, 4, 5, 6) ) (टपल को सेट में टाइप-कास्ट करना) या {1, 2, 3, 1, 2, 3, 4, 5, 6, 4, 5, 6} (एक साधारण सेट), तीनों {1, 2, 3, 4, 5, 6} (सेट में केवल अद्वितीय आइटम होते हैं) आउटपुट या रिटर्न देंगे।
my_set = {1, 2, 3, 1, 2, 3, 4, 5, 6, 4, 5, 6}
print( my_set ) # आउटपुट {1, 2, 3, 4, 5, 6} है।
new_set = set() # {} घुंघराले ब्रेसिज़ का उपयोग न करें, जो एक डिक्शनरी बनाएगा।for num in my_set:
new_set.add( num )
print( new_set ) # आउटपुट {1, 2, 3, 4, 5, 6} है।
उदाहरण 17: उपरोक्त उदाहरणों का उपयोग करते समय for लूप में परिभाषित किया गया num (स्थानीय चर) का उपयोग निरंतरता में नहीं करें। अन्यथा, आपको त्रुटि या अप्रत्याशित परिणाम मिल सकता है। याद रखें, प्रोग्राम में त्रुटि या बग तब होते हैं, जब प्रोग्रामर (इंसान) इन छोटी गलतियों (silly mistakes) पर ध्यान नहीं देता है!! BUG कोई त्रुटि नहीं है, बल्कि एक अप्रत्याशित व्यवहार है जिसे पायथन इन्टरप्रेटर द्वारा प्रदर्शित नहीं किया जा सकता है।
my_set = {1, 2, 3, 1, 2, 3, 4, 5, 6, 4, 5, 6}
new_set = {num for num in my_set}
print( new_set ) # आउटपुट {1, 2, 3, 4, 5, 6} है।
Leave a Comment:
Amit Sinha March 2nd, 2023 at 9:30 PM
😃 😄 😁 😆 😅 😂 😉 😊 😇 😍 😘 😚 😋 😜 😝 😶 😏 😒 😌 😔 😪 😷 😵 😎 😲 😳 😨 😰 😥 😢 😭 😱 😖 😣 😞 😓 😩 😫 😤
Ribhu March 3rd, 2023 at 9:30 PM
🐵 🐒 🐶 🐩 🐺 🐱 🐯 🐅 🐆 🐴 🐎 🐮 🐂 🐃 🐄 🐷 🐖 🐗 🐽 🐏 🐑 🐐 🐪 🐫 🐘 🐭 🐁 🐀 🐹 🐰 🐇
