वाईएएमएल

वाईएएमएल (देखना ) एक मानव-पठनीय क्रमांकन|डेटा-क्रमांकन भाषा है। इसका उपयोग आमतौर पर विन्यास फाइल और उन अनुप्रयोगों में किया जाता है जहां डेटा संग्रहीत या प्रसारित किया जा रहा है। YAML  एक्सटेंसिबल मार्कअप लैंग्वेज  (XML) के समान कई संचार अनुप्रयोगों को लक्षित करता है, लेकिन इसमें न्यूनतम सिंटैक्स होता है जो जानबूझकर मानक सामान्यीकृत मार्कअप लैंग्वेज (SGML) से भिन्न होता है। यह नेस्टिंग को इंगित करने के लिए पायथन (प्रोग्रामिंग भाषा) शैली इंडेंटेशन और अधिक कॉम्पैक्ट प्रारूप दोनों का उपयोग करता है [...] सूचियों के लिए और {...} मानचित्रों के लिए लेकिन टैब वर्णों को इंडेंटेशन के रूप में उपयोग करने से रोकता है इस प्रकार केवल कुछ JSON फ़ाइलें ही मान्य YAML 1.2 हैं। कस्टम डेटा प्रकारों की अनुमति है, लेकिन YAML मूल रूप से अदिश (कंप्यूटिंग)  (जैसे स्ट्रिंग (कंप्यूटर विज्ञान), इंटीजर (कंप्यूटर विज्ञान), और तैरनेवाला स्थल), सूची (कंप्यूटिंग), और सहयोगी सरणी (जिसे मानचित्र, शब्दकोश या के रूप में भी जाना जाता है) को एन्कोड करता है। हैश)। ये डेटा प्रकार पर्ल प्रोग्रामिंग भाषा पर आधारित हैं, हालांकि आमतौर पर उपयोग की जाने वाली सभी उच्च-स्तरीय प्रोग्रामिंग भाषाएं बहुत समान अवधारणाएं साझा करती हैं।   कोलन-केंद्रित सिंटैक्स, विशेषता-मूल्य जोड़ी | कुंजी-मूल्य जोड़े को व्यक्त करने के लिए उपयोग किया जाता है, इलेक्ट्रॉनिक मेल हेडर से प्रेरित है जैसा कि इसमें परिभाषित किया गया है, और सीमान्तक --- MIME से उधार लिया गया है . एस्केप अनुक्रमों का पुन: उपयोग C (प्रोग्रामिंग भाषा) से किया जाता है, और मल्टी-लाइन स्ट्रिंग्स के लिए व्हाइटस्पेस रैपिंग HTML से प्रेरित है। सूचियों और हैश में नेस्टेड सूचियाँ और हैश शामिल हो सकते हैं, जो एक वृक्ष संरचना बनाते हैं; मनमाना ग्राफ़ (अमूर्त डेटा प्रकार) को YAML उपनामों (SOAP में XML के समान) का उपयोग करके दर्शाया जा सकता है। YAML का उद्देश्य स्ट्रीम में पढ़ना और लिखना है, यह XML के लिए Simple API से प्रेरित एक सुविधा है।

YAML को पढ़ने और लिखने के लिए समर्थन कई प्रोग्रामिंग भाषाओं के लिए उपलब्ध है। कुछ स्रोत-कोड संपादक जैसे विम (पाठ संपादक), Emacs, और विभिन्न एकीकृत विकास वातावरण  इसमें ऐसी विशेषताएं हैं जो YAML को संपादित करना आसान बनाती हैं, जैसे नेस्टेड संरचनाओं को मोड़ना या सिंटैक्स त्रुटियों को स्वचालित रूप से हाइलाइट करना।

YAML फ़ाइलों के लिए आधिकारिक अनुशंसित फ़ाइल नाम एक्सटेंशन रहा है .yaml 2006 से।

इतिहास और नाम
वाईएएमएल (, ऊँट के साथ तुकबंदी करता है पहली बार 2001 में क्लार्क इवांस द्वारा प्रस्तावित किया गया था, जिन्होंने Ingy dot Net के साथ मिलकर इसे डिज़ाइन किया है और ओरेन बेन-किकी। मूल रूप से YAML का अर्थ एक और मार्कअप भाषा कहा जाता था, क्योंकि यह उस युग में जारी किया गया था जिसमें प्रस्तुति और कनेक्टिविटी (HTML, XML, SGML, आदि) के लिए मार्कअप भाषाओं का प्रसार देखा गया था। इसका प्रारंभिक नाम मौखिक संदर्भ के रूप में था प्रौद्योगिकी परिदृश्य में, इसके उद्देश्य को एक अन्य निर्माण के साथ एक मार्कअप भाषा के रूप में संदर्भित किया गया था, लेकिन फिर इसे डेटा-उन्मुख के रूप में इसके उद्देश्य को अलग करने के लिए, एक पुनरावर्ती संक्षिप्त नाम, YAML इज़ नॉट पाठ के प्रस्तुतिकरण के लिए प्रयुक्त भाषा  के रूप में पुनर्निर्मित किया गया था। दस्तावेज़ मार्कअप की तुलना में.

सिंटेक्स
आधिकारिक साइट पर एक चीट शीट और पूर्ण विवरण उपलब्ध हैं। निम्नलिखित मूल तत्वों का सारांश है।

YAML कुछ नियंत्रण वर्णों को छोड़कर संपूर्ण यूनिकोड वर्ण सेट को स्वीकार करता है, और इसे UTF-8, UTF-16 या UTF-32 में से किसी एक में एन्कोड किया जा सकता है। (हालाँकि UTF-32 अनिवार्य नहीं है, पार्सर के लिए JSON संगतता होना आवश्यक है।)
 * व्हाइटस्पेस (कंप्यूटर विज्ञान) इंडेंट शैली का उपयोग संरचना को दर्शाने के लिए किया जाता है; हालाँकि, उस इंडेंटेशन के भाग के रूप में टैब वर्णों की अनुमति नहीं है।
 * टिप्पणियाँ संख्या चिह्न से शुरू होती हैं (#), किसी लाइन पर कहीं भी शुरू हो सकता है और लाइन के अंत तक जारी रह सकता है। टिप्पणियों को व्हाइटस्पेस वर्णों द्वारा अन्य टोकन से अलग किया जाना चाहिए। यदि # अक्षर एक स्ट्रिंग के अंदर दिखाई देते हैं, तो वे संख्या चिह्न हैं (#) शाब्दिक.
 * सूची के सदस्यों को एक अग्रणी हाइफ़न-माइनस द्वारा दर्शाया जाता है (-) प्रति पंक्ति एक सदस्य के साथ।
 * एक सूची को वर्गाकार कोष्ठकों में पाठ संलग्न करके भी निर्दिष्ट किया जा सकता है ([...]) प्रत्येक प्रविष्टि को अल्पविराम (विराम चिह्न) द्वारा अलग किया जाता है।
 * एक सहयोगी सरणी प्रविष्टि को फॉर्म कुंजी में कोलन (विराम चिह्न) स्पेस (विराम चिह्न) का उपयोग करके दर्शाया जाता है: प्रति पंक्ति एक प्रविष्टि के साथ मान। YAML के लिए जरूरी है कि कोलन के बाद एक स्पेस हो ताकि यूआरएल-स्टाइल स्ट्रिंग्स एक जैसी हो जाएं http://www.wikipedia.org को उद्धरण चिह्नों में संलग्न किए बिना दर्शाया जा सकता है।
 * प्रश्न चिह्न का उपयोग कुंजी के सामने ?key: मान के रूप में किया जा सकता है, जिससे कुंजी में बिना उद्धरण चिह्नों के अग्रणी डैश, वर्गाकार कोष्ठक आदि शामिल हो सकें।
 * एक सहयोगी सरणी को घुंघराले ब्रेसिज़ में संलग्न पाठ द्वारा भी निर्दिष्ट किया जा सकता है ({...}), कुंजियों को कोलन द्वारा मानों से अलग किया जाता है और प्रविष्टियों को अल्पविराम से अलग किया जाता है (JSON के साथ संगतता बनाए रखने के लिए रिक्त स्थान की आवश्यकता नहीं होती है)।
 * स्ट्रिंग (कंप्यूटर विज्ञान) (वाईएएमएल में एक प्रकार का स्केलर) आमतौर पर उद्धृत नहीं किया जाता है, लेकिन दोहरे उद्धरण चिह्न में संलग्न किया जा सकता है|दोहरे उद्धरण चिह्न ("), या एकल उद्धरण|एकल-उद्धरण (').
 * डबल-कोट्स के भीतर, विशेष वर्णों को सी (प्रोग्रामिंग भाषा) के साथ दर्शाया जा सकता है | बैकस्लैश से शुरू होने वाले सी-शैली एस्केप अनुक्रम (\). दस्तावेज़ीकरण के अनुसार केवल ऑक्टल एस्केप समर्थित है \0.
 * एकल उद्धरण के भीतर एकमात्र समर्थित एस्केप अनुक्रम एक दोगुना एकल उद्धरण है () एकल उद्धरण को स्वयं के रूप में निरूपित करना 'dont'.
 * ब्लॉक स्केलर को संरक्षित करने के लिए वैकल्पिक संशोधक के साथ इंडेंट शैली के साथ सीमांकित किया गया है या मोड़ो (>) नई पंक्तियाँ।
 * एक ही स्ट्रीम में एकाधिक दस्तावेज़ों को तीन हाइफ़न द्वारा अलग किया जाता है (---).
 * तीन पूर्ण विराम (...) वैकल्पिक रूप से किसी दस्तावेज़ को एक स्ट्रीम के भीतर समाप्त करें।
 * दोहराए गए नोड्स को प्रारंभ में एक एम्परसेंड द्वारा दर्शाया जाता है (&) और उसके बाद तारांकन चिह्न के साथ संदर्भित (*).
 * दोहरे विस्मयादिबोधक चिह्न का उपयोग करके नोड्स को एक प्रकार या टैग के साथ लेबल किया जा सकता है (!!) के बाद एक स्ट्रिंग आती है, जिसे यूआरआई में विस्तारित किया जा सकता है।
 * एक स्ट्रीम में YAML दस्तावेज़ों के पहले एक प्रतिशत चिह्न से बना 'निर्देश' हो सकता है (%) के बाद एक नाम और स्थान-सीमांकित पैरामीटर आते हैं। YAML 1.1 में दो निर्देश परिभाषित हैं:
 * किसी दिए गए दस्तावेज़ में YAML के संस्करण की पहचान करने के लिए %YAML निर्देश का उपयोग किया जाता है।
 * %TAG निर्देश का उपयोग URI उपसर्गों के शॉर्टकट के रूप में किया जाता है। फिर इन शॉर्टकट्स का उपयोग नोड प्रकार टैग में किया जा सकता है।

बुनियादी घटक
पारंपरिक ब्लॉक प्रारूप सूची में एक नया आइटम शुरू करने के लिए एक हाइफ़न+स्पेस का उपयोग करता है। वैकल्पिक इनलाइन प्रारूप को अल्पविराम+स्पेस द्वारा सीमांकित किया गया है और कोष्ठक में संलग्न किया गया है (जावास्क्रिप्ट ऑब्जेक्ट नोटेशन के समान)। कुंजियाँ को कोलन+स्पेस द्वारा मानों से अलग किया जाता है। इंडेंटेड ब्लॉक, जो YAML डेटा फ़ाइलों में आम हैं, कुंजी/मूल्य जोड़े को अलग करने के लिए इंडेंटेशन और नई लाइनों का उपयोग करते हैं। इनलाइन ब्लॉक, जो कि YAML डेटा स्ट्रीम में आम है, ब्रेसिज़ के बीच कुंजी/मान जोड़े को अलग करने के लिए अल्पविराम+स्पेस का उपयोग करते हैं। स्ट्रिंग्स को उद्धरण चिह्नों की आवश्यकता नहीं है. मल्टी-लाइन स्ट्रिंग्स लिखने के दो तरीके हैं, एक न्यूलाइन्स को संरक्षित करना (का उपयोग करना)।  कैरेक्टर) और वह जो न्यूलाइन्स को फोल्ड करता है (का उपयोग करके)। > वर्ण), दोनों के बाद एक नई पंक्ति वर्ण आता है।

डिफ़ॉल्ट रूप से, अग्रणी इंडेंटेशन (पहली पंक्ति का) और अनुगामी रिक्त स्थान हटा दिए जाते हैं, हालांकि अन्य व्यवहार को स्पष्ट रूप से निर्दिष्ट किया जा सकता है।

मुड़ा हुआ पाठ नई पंक्तियों को रिक्त स्थान में परिवर्तित करता है और प्रमुख रिक्त स्थान को हटा देता है।

ऑब्जेक्ट और सूचियाँ yaml में महत्वपूर्ण घटक हैं और इन्हें मिश्रित किया जा सकता है। पहला उदाहरण कुंजी-मूल्य वाली वस्तुओं की एक सूची है, सभी स्मिथ परिवार के लोग हैं। दूसरा उन्हें लिंग के आधार पर सूचीबद्ध करता है; यह एक कुंजी-मूल्य वाली वस्तु है जिसमें दो सूचियाँ हैं।

उन्नत घटक
दो विशेषताएं जो YAML को अन्य डेटा-क्रमांकन भाषाओं की क्षमताओं से अलग करती हैं, वे संरचनाएं हैं और डेटा टाइपिंग।

YAML संरचनाएं एक ही फ़ाइल के भीतर कई दस्तावेज़ों के भंडारण, बार-बार नोड्स के लिए संदर्भों के उपयोग और कुंजी के रूप में मनमाने नोड्स के उपयोग को सक्षम करती हैं।

स्पष्टता, सघनता और डेटा प्रविष्टि त्रुटियों से बचने के लिए, YAML नोड एंकर (उपयोग करके) प्रदान करता है &) और संदर्भ (उपयोग करके)। *). एंकर के संदर्भ सभी डेटा प्रकारों के लिए काम करते हैं (नीचे दिए गए उदाहरण में शिप-टू संदर्भ देखें)।

नीचे एक उपकरण अनुक्रमक में एक कतार का उदाहरण दिया गया है जिसमें दो चरणों को हर बार पूरी तरह से वर्णित किए बिना बार-बार पुन: उपयोग किया जाता है।

अधिकांश YAML दस्तावेज़ों में स्पष्ट डेटा टाइपिंग शायद ही कभी देखी जाती है क्योंकि YAML सरल प्रकारों का स्वत: पता लगाता है। डेटा प्रकारों को तीन श्रेणियों में विभाजित किया जा सकता है: कोर, परिभाषित और उपयोगकर्ता-परिभाषित। कोर से किसी भी पार्सर में मौजूद होने की उम्मीद की जाती है (उदाहरण के लिए फ्लोट्स, इनट्स, स्ट्रिंग्स, सूचियां, मानचित्र, ...)। कई और उन्नत डेटा प्रकार, जैसे बाइनरी डेटा, को YAML विनिर्देश में परिभाषित किया गया है लेकिन सभी कार्यान्वयन में समर्थित नहीं है। अंत में YAML उपयोगकर्ता-परिभाषित वर्गों, संरचनाओं या प्राइमेटिव्स (उदाहरण के लिए क्वाड-प्रिसिजन फ्लोट्स) को समायोजित करने के लिए स्थानीय रूप से डेटा प्रकार परिभाषाओं को विस्तारित करने का एक तरीका परिभाषित करता है।

YAML इकाई के डेटाटाइप का स्वतः पता लगाता है, लेकिन कभी-कभी कोई डेटाटाइप को स्पष्ट रूप से डालना चाहता है। सबसे आम स्थिति वह है जहां एक एकल-शब्द स्ट्रिंग जो एक संख्या, बूलियन या टैग की तरह दिखती है, उसे उद्धरण चिह्नों के साथ घेरकर या स्पष्ट डेटाटाइप टैग का उपयोग करके अस्पष्टता की आवश्यकता होती है।

YAML के प्रत्येक कार्यान्वयन में प्रत्येक विनिर्देश-परिभाषित डेटा प्रकार नहीं होता है। ये अंतर्निहित प्रकार एक डबल-विस्मयादिबोधक सिगिल (कंप्यूटर प्रोग्रामिंग) उपसर्ग का उपयोग करते हैं (!!). विशेष रूप से दिलचस्प जो यहां नहीं दिखाए गए हैं वे सेट, ऑर्डर किए गए मानचित्र, टाइमस्टैम्प और हेक्साडेसिमल हैं। यहां बेस64-एन्कोडेड बाइनरी डेटा का एक उदाहरण दिया गया है।

YAML के कई कार्यान्वयन ऑब्जेक्ट क्रमांकन के लिए उपयोगकर्ता-परिभाषित डेटा प्रकारों का समर्थन कर सकते हैं। स्थानीय डेटा प्रकार सार्वभौमिक डेटा प्रकार नहीं हैं, लेकिन इन्हें YAML पार्सर लाइब्रेरी का उपयोग करके एप्लिकेशन में परिभाषित किया गया है। स्थानीय डेटा प्रकार एकल विस्मयादिबोधक चिह्न का उपयोग करते हैं (!).

उदाहरण
डेटा-संरचना पदानुक्रम को रूपरेखा इंडेंटेशन द्वारा बनाए रखा जाता है।

ध्यान दें कि स्ट्रिंग्स को उद्धरण चिह्नों में संलग्न करने की आवश्यकता नहीं है। इंडेंटेशन में रिक्त स्थान की विशिष्ट संख्या तब तक महत्वहीन है जब तक समानांतर तत्वों का बायां औचित्य समान होता है और पदानुक्रमित रूप से नेस्टेड तत्वों को आगे इंडेंट किया जाता है। यह नमूना दस्तावेज़ 7 शीर्ष स्तरीय कुंजियों के साथ एक सहयोगी सरणी को परिभाषित करता है: कुंजी में से एक, आइटम में 2-तत्व सूची होती है, जिनमें से प्रत्येक तत्व स्वयं अलग-अलग कुंजी के साथ एक सहयोगी सरणी है। संबंधपरक डेटा और अतिरेक निष्कासन प्रदर्शित किया जाता है: शिप-टू एसोसिएटिव एरे सामग्री को बिल-टू एसोसिएटिव एरे की सामग्री से कॉपी किया जाता है जैसा कि एंकर द्वारा दर्शाया गया है (&) और संदर्भ (*) लेबल. पठनीयता के लिए वैकल्पिक रिक्त पंक्तियाँ जोड़ी जा सकती हैं। एकाधिक दस्तावेज़ एक ही फ़ाइल/स्ट्रीम में मौजूद हो सकते हैं और अलग-अलग होते हैं ---. एक वैकल्पिक ... का उपयोग फ़ाइल के अंत में किया जा सकता है (पाइप को बंद किए बिना स्ट्रीम किए गए संचार के अंत का संकेत देने के लिए उपयोगी)।

इंडेंटेड परिसीमन
क्योंकि YAML मुख्य रूप से संरचना के लिए रूपरेखा इंडेंटेशन पर निर्भर करता है, यह विशेष रूप से सीमांकक टकराव के लिए प्रतिरोधी है। स्केलर मानों में उद्धरण चिह्नों और ब्रेसिज़ के प्रति YAML की असंवेदनशीलता का मतलब है कि कोई XML, JSON या यहां तक ​​कि YAML दस्तावेज़ों को YAML दस्तावेज़ के अंदर बस एक ब्लॉक शाब्दिक में इंडेंट करके एम्बेड कर सकता है (का उपयोग करके)  या >):

YAML को सभी आंतरिक उद्धरण चिह्नों को उद्धृत करके और उनसे बचकर JSON में रखा जा सकता है। YAML को आरक्षित वर्णों से बचकर XML में रखा जा सकता है (<, >, &, ', ") और व्हाइटस्पेस को परिवर्तित करके, या इसे सीडीएटीए अनुभाग में रखकर।

गैर-पदानुक्रमित डेटा मॉडल
JSON के विपरीत, जो केवल एक एकल अभिभावक वाले प्रत्येक चाइल्ड नोड के साथ एक पदानुक्रमित मॉडल में डेटा का प्रतिनिधित्व कर सकता है, YAML एक सरल संबंधपरक योजना भी प्रदान करता है जो समान डेटा के दोहराव को अनावश्यक रूप से दर्ज करने के बजाय पेड़ में दो या दो से अधिक बिंदुओं से संदर्भित करने की अनुमति देता है। वे बिंदु. यह XML में निर्मित IDREF सुविधा के समान है। फिर YAML पार्सर इन संदर्भों को पूरी तरह से भरे हुए डेटा संरचनाओं में विस्तारित करता है, जिन्हें पढ़ते समय वे दर्शाते हैं, इसलिए जो भी प्रोग्राम पार्सर का उपयोग कर रहा है, उसे XML प्रोसेसर के विपरीत, रिलेशनल एन्कोडिंग मॉडल के बारे में पता होना जरूरी नहीं है, जो संदर्भों का विस्तार नहीं करता है। यह विस्तार कॉन्फ़िगरेशन फ़ाइलों या प्रोसेसिंग प्रोटोकॉल में डेटा प्रविष्टि त्रुटियों को कम करते हुए पठनीयता को बढ़ा सकता है, जहां रिकॉर्ड की अनुक्रमिक श्रृंखला में कई पैरामीटर समान रहते हैं जबकि केवल कुछ भिन्न होते हैं। एक उदाहरण यह है कि इनवॉइस में शिप-टू और बिल-टू रिकॉर्ड लगभग हमेशा एक ही डेटा होते हैं।

व्यावहारिक विचार
YAML लाइन-ओरिएंटेड है और इस प्रकार मौजूदा प्रोग्रामों के असंरचित आउटपुट को YAML प्रारूप में परिवर्तित करना अक्सर आसान होता है, जबकि उनमें मूल दस्तावेज़ का अधिकांश स्वरूप बरकरार रहता है। चूँकि संतुलन के लिए कोई समापन टैग, ब्रेसिज़ या उद्धरण चिह्न नहीं हैं, इसलिए आम तौर पर अपरिष्कृत कार्यक्रमों के भीतर वितरित प्रिंट स्टेटमेंट से सीधे अच्छी तरह से गठित YAML उत्पन्न करना आसान होता है। इसी तरह, व्हाइटस्पेस डिलीमीटर ग्रेप, AWK, पर्ल, रूबी और पायथन में लाइन-ओरिएंटेड कमांड का उपयोग करके YAML फ़ाइलों की त्वरित और गंदी फ़िल्टरिंग की सुविधा प्रदान करता है।

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

विपरीत रूप से, हालांकि इसका इंडेंटेड परिसीमन गहराई से निहित पदानुक्रमों को जटिल बनाता प्रतीत हो सकता है, YAML इंडेंट को एक एकल स्थान जितना छोटा संभालता है, और यह मार्कअप भाषाओं की तुलना में बेहतर संपीड़न प्राप्त कर सकता है। इसके अतिरिक्त, अत्यधिक गहरे इंडेंटेशन से पूरी तरह से बचा जा सकता है: 1) इंडेंटेशन के बिना इनलाइन शैली (यानी JSON-जैसे प्रारूप) पर वापस लौटना; या 2) पदानुक्रम को एक सपाट रूप में खोलने के लिए रिलेशनल एंकर का उपयोग करना, जिसे YAML पार्सर पारदर्शी रूप से पूर्ण डेटा संरचना में पुनर्गठित करेगा।

सुरक्षा
YAML पूरी तरह से एक डेटा-प्रस्तुति भाषा है और इस प्रकार इसमें कोई निष्पादन योग्य कमांड नहीं है। जबकि एप्लिकेशन सुरक्षा और क्लाइंट में JavaScript#गलत विश्वास किसी भी डेटा भाषा में स्वाभाविक रूप से संभव है, कार्यान्वयन इतना कुख्यात नुकसान है कि YAML की संबंधित कमांड भाषा की कमी एक सापेक्ष सुरक्षा लाभ हो सकती है।

हालाँकि, YAML भाषा-विशिष्ट टैग की अनुमति देता है ताकि उन टैग का समर्थन करने वाले पार्सर द्वारा मनमाना स्थानीय ऑब्जेक्ट बनाया जा सके। कोई भी YAML पार्सर जो परिष्कृत ऑब्जेक्ट इंस्टेंटेशन को निष्पादित करने की अनुमति देता है, इंजेक्शन हमले की संभावना को खोलता है। पर्ल पार्सर्स जो मनमानी कक्षाओं की वस्तुओं को लोड करने की अनुमति देते हैं, तथाकथित धन्य मान बनाते हैं। इन मानों का उपयोग अप्रत्याशित व्यवहार को ट्रिगर कर सकता है, उदा. यदि कक्षा अतिभारित ऑपरेटरों का उपयोग करती है। इससे मनमाने ढंग से पर्ल कोड का निष्पादन हो सकता है।

स्थिति पायथन या रूबी पार्सर्स के लिए समान है। PyYAML दस्तावेज़ के अनुसार:  ध्यान दें कि यदि आप इंटरनेट जैसे किसी अविश्वसनीय स्रोत से YAML दस्तावेज़ प्राप्त करते हैं तो एक मनमाना पायथन ऑब्जेक्ट बनाने की क्षमता खतरनाक हो सकती है। कार्यक्रम yaml.safe_load इस क्षमता को सरल पायथन ऑब्जेक्ट्स जैसे पूर्णांक या सूचियों तक सीमित करता है। [...]

PyYAML आपको किसी भी प्रकार का पायथन ऑब्जेक्ट बनाने की अनुमति देता है। यहां तक ​​कि पायथन कक्षाओं के उदाहरणों का निर्माण भी इसका उपयोग करके किया जा सकता है !!python/object दिन। 

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

JSON के साथ तुलना
जावास्क्रिप्ट ऑब्जेक्ट नोटेशन सिंटैक्स YAML संस्करण 1.2 का आधार है, जिसे YAML को एक आधिकारिक उपसमुच्चय के रूप में JSON के अनुपालन में लाने के स्पष्ट उद्देश्य से प्रख्यापित किया गया था। हालाँकि YAML के पूर्व संस्करण पूरी तरह से संगत नहीं थे, विसंगतियाँ शायद ही ध्यान देने योग्य थीं, और अधिकांश JSON दस्तावेज़ों को Syck जैसे कुछ YAML पार्सर्स द्वारा पार्स किया जा सकता है। ऐसा इसलिए है क्योंकि JSON की सिमेंटिक संरचना YAML लिखने की वैकल्पिक इनलाइन-शैली के बराबर है। जबकि विस्तारित पदानुक्रम को JSON जैसी इनलाइन-शैली में लिखा जा सकता है, यह अनुशंसित YAML शैली नहीं है, सिवाय इसके कि जब यह स्पष्टता में सहायता करता है।

YAML में कई अतिरिक्त सुविधाएं हैं जो JSON में मौजूद नहीं हैं, जिनमें टिप्पणियाँ, एक्स्टेंसिबल डेटा प्रकार, रिलेशनल एंकर, उद्धरण चिह्नों के बिना स्ट्रिंग और कुंजी क्रम को संरक्षित करने वाले मैपिंग प्रकार शामिल हैं।

कॉन्सिज़न के कारण, JSON क्रमबद्धता और डिसेरिएलाइज़ेशन YAML की तुलना में बहुत तेज़ है।

TOML के साथ तुलना
TOML को INI_file|.ini फ़ाइल स्वरूप की उन्नति के रूप में डिज़ाइन किया गया था। YAML द्वारा सूचक वर्णों के न्यूनतम उपयोग की तुलना TOML द्वारा उद्धरण चिह्नों और वर्गाकार कोष्ठकों की सख्त आवश्यकता से की जाती है। YAML का ऑफ-साइड_रूल और नेस्टिंग का उपयोग कम वर्बोज़ संरचनाओं की अनुमति देता है, एक ऐसी सुविधा जो TOML के पास तुलनीय वाक्यात्मक स्तर पर नहीं है, इसके बजाय समान अर्थ संरचना को व्यक्त करने के लिए वे अपनी कुंजी और तालिका नामों में Properties_(programming)#Dot_notation पर निर्भर हैं।.

एक्सएमएल के साथ तुलना
YAML में XML में पाए जाने वाले टैग विशेषताओं की अवधारणा का अभाव है। इसके बजाय YAML में एक्स्टेंसिबल प्रकार की घोषणाएँ हैं (वस्तुओं के लिए वर्ग प्रकार सहित)।

YAML में स्वयं XML की भाषा-परिभाषित दस्तावेज़ स्कीमा डिस्क्रिप्टर नहीं है जो, उदाहरण के लिए, किसी दस्तावेज़ को स्व-सत्यापित करने की अनुमति देता है। हालाँकि, YAML के लिए कई बाहरी रूप से परिभाषित स्कीमा डिस्क्रिप्टर भाषाएँ हैं (उदाहरण के लिए सिद्धांत (PHP)PHP), Kwalify और Rx) जो उस भूमिका को पूरा करती हैं। इसके अलावा, YAML दस्तावेज़ में YAML की भाषा-परिभाषित प्रकार की घोषणाओं द्वारा प्रदान किया गया शब्दार्थ अक्सर सरल, सामान्य स्थितियों में एक सत्यापनकर्ता की आवश्यकता को कम करता है। इसके अतिरिक्त, YAXML, जो XML में YAML डेटा संरचनाओं का प्रतिनिधित्व करता है, XML स्कीमा आयातकों और एक्स्टेंसिबल स्टाइलशीट भाषा परिवर्तन जैसे आउटपुट तंत्र को YAML पर लागू करने की अनुमति देता है।

डेटा-क्रमबद्धता प्रारूपों की तुलना अन्य क्रमबद्धता प्रारूपों के साथ YAML की अधिक व्यापक तुलना प्रदान करती है।

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

कई लोकप्रिय भाषाओं के लिए YAML एमिटर और पार्सर मौजूद हैं। उनमें से अधिकांश मूल भाषा में ही लिखे गए हैं। कुछ सी लाइब्रेरी libyaml की भाषा बाइंडिंग हैं; वे तेज़ दौड़ सकते हैं। वहाँ एक और सी लाइब्रेरी हुआ करती थी, जिसे सिक कहा जाता था, जो भाग्यशाली स्टिफ़ के कारण लिखी गई और अनाथ हो गई: इसका रखरखाव नहीं किया गया है, कोई आधिकारिक स्रोत बंडल नहीं है, और वेब साइट को हाईजैक कर लिया गया है। इसलिए एकमात्र अनुशंसित सी लाइब्रेरी libyaml है। इसे मूल रूप से किरिल सिमोनोव द्वारा विकसित किया गया था। 2018 में, नए अनुरक्षक इयान कॉर्डास्को और इंगी डॉट नेट द्वारा विकास फिर से शुरू किया गया। C++ प्रोग्रामर के पास C लाइब्रेरी libyaml और C++ लाइब्रेरी libyaml-cpp के बीच विकल्प होता है। दोनों के पास पूरी तरह से स्वतंत्र कोड आधार और पूरी तरह से अलग अप्लिकेशन प्रोग्रामिंग अंतरफलक है। लाइब्रेरी libyaml-cpp में अभी भी प्रमुख संस्करण संख्या 0 है, जो दर्शाता है कि एपीआई किसी भी समय बदल सकता है, जैसा कि वास्तव में संस्करण 0.3 के बाद हुआ था। नेस्टेड तत्वों के विस्तार के उद्देश्य से C# में एक व्याकरण-केंद्रित कार्यान्वयन लिखा गया है। YAML के कुछ कार्यान्वयन, जैसे कि पर्ल का YAML.pm, एक संपूर्ण फ़ाइल (स्ट्रीम) लोड करेगा और इसे सामूहिक रूप से पार्स करेगा। PyYaml जैसे अन्य कार्यान्वयन आलसी हैं और अनुरोध पर ही अगले दस्तावेज़ पर पुनरावृत्त होते हैं। बहुत बड़ी फ़ाइलों के लिए जिनमें दस्तावेज़ों को स्वतंत्र रूप से संभालने की योजना है, प्रसंस्करण से पहले पूरी फ़ाइल को तुरंत चालू करना निषेधात्मक हो सकता है। इस प्रकार YAML.pm में, कभी-कभी किसी फ़ाइल को दस्तावेज़ों में विभाजित करना पड़ता है और उन्हें अलग-अलग पार्स करना पड़ता है। YAML इसे आसान बनाता है, क्योंकि इसके लिए दस्तावेज़ के अंत मार्कर पर विभाजन की आवश्यकता होती है, जिसे एक पंक्ति की शुरुआत में तीन अवधियों के रूप में परिभाषित किया जाता है जिसके बाद एक रिक्त स्थान (और संभवतः एक टिप्पणी) होती है। यह मार्कर सामग्री में वर्जित है.

आलोचना
YAML की इसके महत्वपूर्ण रिक्त स्थान, भ्रमित करने वाली विशेषताओं, असुरक्षित डिफ़ॉल्ट और इसके जटिल और अस्पष्ट विनिर्देश के लिए आलोचना की गई है: YAML की कथित खामियों और जटिलता के कारण strictYAML और NestedText जैसे सख्त विकल्प सामने आए हैं।
 * कॉन्फ़िगरेशन फ़ाइलें उपयोगकर्ताओं को इसका एहसास हुए बिना कमांड निष्पादित कर सकती हैं या सामग्री लोड कर सकती हैं। * बड़ी YAML फ़ाइलों को संपादित करना कठिन है, क्योंकि इंडेंटेशन त्रुटियों पर ध्यान नहीं दिया जा सकता है। * टाइप ऑटोडिटेक्शन त्रुटियों का एक स्रोत है। उदाहरण के लिए, अउद्धृत Yes और NO बूलियन में परिवर्तित हो जाते हैं; सॉफ़्टवेयर संस्करण संख्याओं को फ़्लोट में परिवर्तित किया जा सकता है।
 * टर्मिनेटर की अनुपस्थिति के कारण काटी गई फ़ाइलों को अक्सर वैध YAML के रूप में समझा जाता है।
 * मानक की जटिलता के कारण असंगत कार्यान्वयन हुआ और भाषा गैर-पोर्टेबल बन गई।

यह भी देखें

 * डेटा-क्रमांकन प्रारूपों की तुलना
 * हल्की मार्कअप भाषा