लिस्ट कॉम्प्रिहेंशन

सूची समझ मौजूदा सूची (कंप्यूटिंग) के आधार पर सूची बनाने के लिए कुछ प्रोग्रामिंग भाषाओं में उपलब्ध प्रोग्रामिंग भाषाओं का एक सिंटैक्स है। यह गणितीय सेट-बिल्डर नोटेशन (सेट कॉम्प्रिहेंशन) के रूप का अनुसरण करता है जो मैप (उच्च-क्रम फ़ंक्शन) और फ़िल्टर (उच्च-ऑर्डर फ़ंक्शन) फ़ंक्शंस के उपयोग से अलग है।

अवलोकन
सेट-बिल्डर नोटेशन में निम्नलिखित उदाहरण पर विचार करें।


 * $$S=\{2\cdot x\mid x \in \mathbb{N},\ x^2>3\}$$

या अक्सर
 * $$S=\{2\cdot x : x \in \mathbb{N},\ x^2>3\}$$

इसे पढ़ा जा सकता है,$$S$$ सभी संख्याओं का 2 बार समुच्चय है $$x$$ऐसा है कि $$x$$ प्राकृतिक संख्याओं के समुच्चय का एक तत्व या सदस्य है ($$\mathbb{N}$$), और $$x$$ चुकता से बड़ा है $$3$$.

सबसे छोटी प्राकृतिक संख्या, x = 1, शर्त x को संतुष्ट करने में विफल रहती है2>3 (शर्त 12>3 गलत है) इसलिए 2·1 को एस में शामिल नहीं किया गया है। अगली प्राकृतिक संख्या, 2, शर्त को पूरा करती है (22>3) जैसा कि हर अन्य प्राकृतिक संख्या करती है। इस प्रकार x में 2, 3, 4, 5... समुच्चय है S सभी संख्याओं से 2 गुना x से मिलकर बना है, यह S = {4, 6, 8, 10,...} द्वारा दिया गया है। दूसरे शब्दों में, S, 2 से बड़ी सभी सम संख्याओं का समुच्चय है।

उदाहरण के इस एनोटेटेड संस्करण में:
 * $$S=\{\underbrace{2\cdot x}_{\color{Violet}{\text{output expression}}}\mid \underbrace{x}_{\color{Violet}{\text{variable}}} \in \underbrace{\mathbb{N}}_{\color{Violet}{\text{input set}}},\ \underbrace{x^2>3}_{\color{Violet}{\text{predicate}}}\}$$


 * $$x$$ एक इनपुट सेट के सदस्यों का प्रतिनिधित्व करने वाला वेरिएबल है।
 * $$\mathbb{N}$$ इनपुट सेट का प्रतिनिधित्व करता है, जो इस उदाहरण में प्राकृतिक संख्याओं का सेट है
 * $$x^2>3$$ एक विधेय (तर्क) अभिव्यक्ति है जो इनपुट सेट के सदस्यों पर फ़िल्टर के रूप में कार्य करती है।
 * $$2\cdot x$$ एक आउटपुट एक्सप्रेशन है जो इनपुट सेट के सदस्यों से नए सेट के सदस्यों का निर्माण करता है जो विधेय अभिव्यक्ति को संतुष्ट करते हैं।
 * $$\{\}$$ ब्रेसिज़ इंगित करते हैं कि परिणाम एक सेट है
 * $$\mid$$ $$,$$ ऊर्ध्वाधर पट्टी को इस प्रकार पढ़ा जाता है। बार और कोलन : का उपयोग परस्पर विनिमय के लिए किया जाता है।
 * अल्पविराम विधेय को अलग करते हैं और इन्हें AND के रूप में पढ़ा जा सकता है।

एक सूची समझ में एक इनपुट सूची (कंप्यूटिंग) या पुनरावर्तक के क्रम में एक सूची की पीढ़ी का प्रतिनिधित्व करने के लिए समान वाक्यात्मक घटक होते हैं: आउटपुट सूची के सदस्यों की पीढ़ी का क्रम इनपुट में वस्तुओं के क्रम पर आधारित है।
 * एक इनपुट सूची के सदस्यों का प्रतिनिधित्व करने वाला एक चर।
 * एक इनपुट सूची (या पुनरावर्तक)।
 * एक वैकल्पिक विधेय अभिव्यक्ति.
 * और एक आउटपुट एक्सप्रेशन, इनपुट पुनरावर्तनीय के सदस्यों से आउटपुट सूची के सदस्यों का उत्पादन करता है जो विधेय को संतुष्ट करते हैं।

हास्केल (प्रोग्रामिंग भाषा)|हास्केल की सूची समझ वाक्यविन्यास में, यह सेट-बिल्डर निर्माण इसी तरह लिखा जाएगा, जैसे: यहाँ, सूची  का प्रतिनिधित्व करता है $$\mathbb{N}$$,   विधेय का प्रतिनिधित्व करता है, और   आउटपुट अभिव्यक्ति का प्रतिनिधित्व करता है।

सूची समझ एक परिभाषित क्रम में परिणाम देती है (सेट के सदस्यों के विपरीत); और सूची समझ जनरेटर (कंप्यूटर विज्ञान) किसी सूची के सदस्यों को क्रम में ला सकता है, न कि पूरी सूची तैयार कर सकता है, उदाहरण के लिए, एक अनंत सूची के सदस्यों की पिछली हास्केल परिभाषा की अनुमति देता है।

इतिहास
संबंधित निर्माणों का अस्तित्व सूची समझ शब्द के उपयोग से पहले का है। SETL प्रोग्रामिंग भाषा (1969) में एक सेट निर्माण संरचना है जो सूची समझ के समान है। उदाहरण के लिए, यह कोड 2 से लेकर सभी अभाज्य संख्याओं को प्रिंट करता है N: प्रिंट([n in [2..N] | forall m in {2..n - 1} | n mod m > 0]); कंप्यूटर बीजगणित प्रणाली Axiom (कंप्यूटर बीजगणित प्रणाली) (1973) में एक समान संरचना है जो स्ट्रीम (कंप्यूटिंग) को संसाधित करती है।

ऐसे निर्माणों के लिए समझ शब्द का पहला उपयोग रॉड बर्स्टल और जॉन डार्लिंगटन द्वारा 1977 से उनकी कार्यात्मक प्रोग्रामिंग भाषा एनपीएल प्रोग्रामिंग भाषा के विवरण में किया गया था। उनके पूर्वव्यापी कार्यात्मक प्रोग्रामिंग भाषाओं के कुछ इतिहास में, डेविड_टर्नर_(कंप्यूटर_वैज्ञानिक) याद करते हैं:

"NPL was implemented in POP2 by Burstall and used for Darlington’s work on program transformation (Burstall & Darlington 1977). The language was first order, strongly (but not polymorphically) typed, purely functional, call-by-value. It also had “set expressions” e.g.
 * setofeven (X) <= <:x : x in X & even(x):>"

}}

शब्द सूची समझ से जुड़े एक फ़ुटनोट में, टर्नर यह भी नोट करता है

"I initially called these ZF expressions, a reference to Zermelo-Frankel set theory — it was Phil Wadler who coined the better term list comprehension."

एनपीएल के साथ बर्स्टॉल और डार्लिंगटन के काम ने 1980 के दशक के दौरान कई कार्यात्मक प्रोग्रामिंग भाषाओं को प्रभावित किया, लेकिन सभी में सूची समझ शामिल नहीं थी। 1985 में जारी टर्नर की प्रभावशाली, शुद्ध, आलसी, कार्यात्मक प्रोग्रामिंग भाषा मिरांडा प्रोग्रामिंग भाषा एक अपवाद थी। बाद में विकसित मानक शुद्ध आलसी कार्यात्मक भाषा हास्केल प्रोग्रामिंग भाषा में सूची समझ सहित मिरांडा की कई विशेषताएं शामिल हैं।

समझ को डेटाबेस के लिए क्वेरी नोटेशन के रूप में प्रस्तावित किया गया था और हेनरिक क्लिस्ली डेटाबेस क्वेरी भाषा में कार्यान्वित किए गए थे।

मोनाड समझ
हास्केल में, कार्यात्मक प्रोग्रामिंग में एक सन्यासी #do-नोटेशन कार्यात्मक प्रोग्रामिंग में अन्य सन्यासियों के लिए सूची समझ का एक सामान्यीकरण है।

समझ सेट करें
पायथन भाषा का संस्करण 3.x और 2.7 सेट (कंप्यूटर विज्ञान) समझ के लिए वाक्यविन्यास का परिचय देता है। सूची समझ के रूप में समान, सेट समझ सूचियों के बजाय पायथन सेट उत्पन्न करती है। रैकेट (प्रोग्रामिंग भाषा) सेट समझ सूचियों के बजाय रैकेट सेट उत्पन्न करती है।

शब्दकोश बोध
पायथन भाषा के संस्करण 3.x और 2.7 ने साहचर्य सरणी समझ के लिए एक नया वाक्यविन्यास पेश किया, जो सूची समझ के रूप में समान है, लेकिन इसके बजाय पायथन dicts उत्पन्न करता है। सूचियों का. रैकेट हैश टेबल समझ रैकेट हैश टेबल उत्पन्न करती है (रैकेट शब्दकोश प्रकार का एक कार्यान्वयन)।

समानांतर सूची समझ
ग्लासगो हास्केल कंपाइलर में समानांतर सूची समझ (जिसे ज़िप-समझ के रूप में भी जाना जाता है) नामक एक एक्सटेंशन है जो सूची समझ वाक्यविन्यास के भीतर क्वालीफायर की कई स्वतंत्र शाखाओं की अनुमति देता है। जबकि अल्पविराम द्वारा अलग किए गए क्वालीफायर आश्रित (नेस्टेड) ​​होते हैं, पाइपों द्वारा अलग किए गए क्वालीफायर शाखाओं का मूल्यांकन समानांतर में किया जाता है (यह मल्टीथ्रेडेडनेस के किसी भी रूप को संदर्भित नहीं करता है: इसका मतलब केवल यह है कि शाखाएं मैप (उच्च-क्रम फ़ंक्शन) हैं)। रैकेट की समझ मानक लाइब्रेरी में इसकी समझ के समानांतर और नेस्टेड संस्करण शामिल हैं, जो नाम में for बनाम for* द्वारा प्रतिष्ठित हैं। उदाहरण के लिए, वेक्टर समझ for/vector और for*/vector अनुक्रमों पर समानांतर बनाम नेस्टेड पुनरावृत्ति द्वारा वैक्टर बनाते हैं। हास्केल सूची समझ उदाहरणों के लिए रैकेट कोड निम्नलिखित है। पायथन में, हम निम्नानुसार कार्य कर सकते हैं: जूलिया में, व्यावहारिक रूप से समान परिणाम निम्नानुसार प्राप्त किए जा सकते हैं: एकमात्र अंतर यह है कि जूलिया में सूचियों के बजाय, हमारे पास सारणियाँ हैं।

XQuery और XPath
मूल एनपीएल उपयोग की तरह, ये मूल रूप से डेटाबेस एक्सेस भाषाएं हैं।

यह समझ की अवधारणा को और अधिक महत्वपूर्ण बनाता है, क्योंकि संपूर्ण सूची को पुनः प्राप्त करना और उस पर काम करना कम्प्यूटेशनल रूप से असंभव है (प्रारंभिक 'संपूर्ण सूची' संपूर्ण XML डेटाबेस हो सकती है)।

XPath में, अभिव्यक्ति: वैचारिक रूप से चरणों की एक श्रृंखला के रूप में मूल्यांकन किया जाता है जहां प्रत्येक चरण एक सूची तैयार करता है और अगला चरण पिछले चरण के आउटपुट में प्रत्येक तत्व पर एक फ़िल्टर फ़ंक्शन लागू करता है। XQuery में, पूर्ण XPath उपलब्ध है, लेकिन FLWOR स्टेटमेंट का भी उपयोग किया जाता है, जो एक अधिक शक्तिशाली समझ निर्माण है। यहां XPath //पुस्तक का मूल्यांकन एक अनुक्रम (उर्फ सूची) बनाने के लिए किया जाता है; जहां खंड एक कार्यात्मक फिल्टर है, परिणाम को क्रमबद्ध करता है, और  XML स्निपेट वास्तव में एक अज्ञात फ़ंक्शन है जो अन्य कार्यात्मक भाषाओं में पाए जाने वाले 'मैप' दृष्टिकोण का उपयोग करके अनुक्रम में प्रत्येक तत्व के लिए XML बनाता/बदलता है।

तो, किसी अन्य कार्यात्मक भाषा में उपरोक्त FLWOR कथन को इस तरह लागू किया जा सकता है:

C# में LINQ
सी शार्प (प्रोग्रामिंग भाषा)|सी# 3.0 में भाषा एकीकृत क्वेरी  नामक संबंधित सुविधाओं का एक समूह है, जो ऑब्जेक्ट गणना में हेरफेर करने के लिए क्वेरी ऑपरेटरों के एक सेट को परिभाषित करता है।

यह एसक्यूएल की याद दिलाते हुए एक वैकल्पिक समझ वाक्यविन्यास भी प्रदान करता है:

LINQ विशिष्ट सूची समझ कार्यान्वयन पर एक क्षमता प्रदान करता है। जब समझ का मूल उद्देश्य कार्यान्वित होता है  इंटरफ़ेस, केवल समझ के जंजीर तरीकों को निष्पादित करने के बजाय, कमांड के पूरे अनुक्रम को एक अमूर्त सिंटैक्स ट्री (एएसटी) ऑब्जेक्ट में परिवर्तित कर दिया जाता है, जिसे व्याख्या और निष्पादित करने के लिए IQueryable ऑब्जेक्ट को पास किया जाता है।

यह, अन्य बातों के अलावा, IQueryable को अनुमति देता है
 * असंगत या अकुशल समझ को फिर से लिखें
 * निष्पादन के लिए एएसटी को किसी अन्य क्वेरी भाषा (जैसे एसक्यूएल) में अनुवाद करें

सी++
C++ में सीधे तौर पर सूची समझ का समर्थन करने वाली कोई भाषा सुविधा नहीं है, लेकिन ऑपरेटर ओवरलोडिंग (उदाहरण के लिए, ओवरलोडिंग) है,  ,  ) एम्बेडेड क्वेरी डोमेन-विशिष्ट भाषाओं (डीएसएल) के लिए अभिव्यंजक वाक्यविन्यास प्रदान करने के लिए सफलतापूर्वक उपयोग किया गया है। वैकल्पिक रूप से, एक कंटेनर में तत्वों का चयन करने के लिए इरेज़-रिमूव मुहावरे का उपयोग करके सूची समझ का निर्माण किया जा सकता है और उन्हें बदलने के लिए STL एल्गोरिदम for_each का उपयोग किया जा सकता है। C++ को सेट बिल्डर नोटेशन के समान सूची-समझ निर्माण/सिंटैक्स प्रदान करने में कुछ प्रयास किए गए हैं। लीसा प्रदान करता है   XPath/विभाजक के लिए. XPath का // विभाजक जो पेड़ में मध्यवर्ती नोड्स को छोड़ देता है उसे LEESA में रणनीतिक प्रोग्रामिंग के रूप में जाना जाता है का उपयोग करके कार्यान्वित किया जाता है। नीचे दिए गए उदाहरण में, कैटलॉग_, पुस्तक_, लेखक_ और नाम_ क्रमशः कैटलॉग, पुस्तक, लेखक और नाम वर्गों के उदाहरण हैं।
 * C++ लाइब्रेरीज़ को बूस्ट करें ़ में। रेंज लाइब्रेरी में एडेप्टर की एक धारणा है  जिसे किसी भी रेंज पर लागू किया जा सकता है और फ़िल्टरिंग, ट्रांसफ़ॉर्मेशन आदि किया जा सकता है। इस लाइब्रेरी के साथ, मूल हास्केल उदाहरण जैसा दिखेगा (गुमनाम फ़िल्टरिंग और ट्रांसफ़ॉर्मिंग के लिए Boost.Lambda  का उपयोग करना) फ़ंक्शन) (पूर्ण उदाहरण):
 * यह कार्यान्वयन एक मैक्रो का उपयोग करता है और << ऑपरेटर को ओवरलोड करता है। यह 'if' के अंदर मान्य किसी भी अभिव्यक्ति का मूल्यांकन करता है, और कोई भी चर नाम चुना जा सकता है। हालाँकि, यह थ्रेड सुरक्षा नहीं है। उपयोग उदाहरण:
 * यह कार्यान्वयन कक्षाओं और ऑपरेटर ओवरलोडिंग का उपयोग करके हेड/टेल स्लाइसिंग प्रदान करता है, और | सूचियों को फ़िल्टर करने के लिए ऑपरेटर (फ़ंक्शन का उपयोग करके)। उपयोग उदाहरण:
 * एंबेडेड क्वेरी और ट्रैवर्सल के लिए भाषा (LEESA)। ) C++ में एक एम्बेडेड DSL है जो ऑपरेटर ओवरलोडिंग का उपयोग करके एक्स-पाथ-जैसी क्वेरीज़ को कार्यान्वित करता है। क्वेरीज़ को XSD से xml-to-c++ बाइंडिंग का उपयोग करके प्राप्त किए गए समृद्ध रूप से टाइप किए गए xml ट्री पर निष्पादित किया जाता है। बिल्कुल कोई स्ट्रिंग एन्कोडिंग नहीं है. यहां तक ​​कि एक्सएमएल टैग के नाम भी कक्षाएं हैं और इसलिए, टाइपो के लिए कोई रास्ता नहीं है। यदि LEESA एक्सप्रेशन गलत पथ बनाता है जो डेटा मॉडल में मौजूद नहीं है, तो C++ कंपाइलर कोड को अस्वीकार कर देगा। एक कैटलॉग xml पर विचार करें।

यह भी देखें

 * सेट-बिल्डर नोटेशन
 * SQL#क्वेरीज़ में इसके FROM और WHERE क्लॉज के साथ सेलेक्ट (SQL) स्टेटमेंट

नोट्स और संदर्भ

 * लिस्ट कॉम्प्रिहेंशन द फ्री ऑन-लाइन डिक्शनरी ऑफ कंप्यूटिंग में, संपादक डेनिस होवे.

बाहरी संबंध

 * SQL-like set operations with list comprehension one-liners in the Python Cookbook
 * Discussion on list comprehensions in Scheme and related constructs
 * List Comprehensions across languages

स्वयंसिद्ध

 * Axiom स्ट्रीम उदाहरण

क्लोजर

 * एपीआई दस्तावेज़ीकरण के लिए - मैक्रो के लिए

सामान्य लिस्प

 * लिस्प कॉम्प्रिहेंशन मैक्रो का कार्यान्वयन गाइ लैपल्मे द्वारा

हास्केल

 * हास्केल 98 रिपोर्ट, अध्याय 3.11 सूची समझ।
 * गौरवशाली ग्लासगो हास्केल संकलन प्रणाली उपयोगकर्ता गाइड, अध्याय html#समानांतर-सूची-समझ 7.3.4 समानांतर सूची समझ।
 * द हग्स 98 उपयोगकर्ता गाइड, अध्याय 5.1. 2 समानांतर सूची समझ (उर्फ ज़िप-समझ)।

OCaml

 * OCaml बैटरियां शामिल
 * OCaml बैटरियों में शामिल भाषा एक्सटेंशन

पायथन

 * पायथॉन ट्यूटोरियल, लिस्ट कॉम्प्रिहेंशन।
 * पायथन भाषा संदर्भ, सूची प्रदर्शित करता है।
 * पायथन एन्हांसमेंट प्रस्ताव PEP 202: सूची समझ।
 * पायथन भाषा संदर्भ, जेनरेटर एक्सप्रेशन।
 * पायथन एन्हांसमेंट प्रस्ताव PEP 289: जेनरेटर एक्सप्रेशंस।

श्रेणी:प्रोग्रामिंग निर्माण श्रेणी:उदाहरण कोड वाले लेख श्रेणी:हास्केल कोड के उदाहरण वाले लेख श्रेणी: पायथन (प्रोग्रामिंग भाषा) कोड के उदाहरण वाले लेख श्रेणी: उदाहरण रैकेट कोड वाले लेख