पायथन वेब डेवलपमेंट लाइब्रेरीज़ - क्विक गाइड
जब भी कोई उपयोगकर्ता Google Chrome या मोज़िला जैसे किसी भी वेब ब्राउज़र को खोलता है और 'वेब विकास' की खोज करता है, तो कुछ ही समय में हजारों परिणाम दिखाई देते हैं। इससे क्या संभव है? वेब विकास! यह मोटे तौर पर इंट्रानेट या इंटरनेट के माध्यम से होस्टिंग के लिए वेबसाइटों के निर्माण, निर्माण और रखरखाव से जुड़े कार्यों को संदर्भित करता है। वेबसाइट डिजाइन में जुड़े कार्य में कई क्षेत्र शामिल हैं: वेब प्रोग्रामिंग, डेटाबेस प्रबंधन, वेब डिजाइन, वेब प्रकाशन, आदि।
वेब डेवलपमेंट में वे सभी कोड शामिल हैं जो वेबसाइट को चलाने के लिए प्रभावित करते हैं। हम वेब विकास की पूरी प्रक्रिया को दो श्रेणियों में अलग कर सकते हैं -
- Front-end
- Back-end
हालाँकि, दृश्यपटल और बैकेंड वेब विकास निश्चित रूप से एक दूसरे से अलग हैं, वे एक ही सिक्के के दो पहलू भी हैं। एक पूरी वेबसाइट एक इकाई के रूप में दूसरे के साथ प्रभावी ढंग से संचार और संचालन करने पर निर्भर करती है। वेब विकास में फ्रंट-एंड और बैक-एंड दोनों समान रूप से महत्वपूर्ण हैं।
किसी एप्लिकेशन का फ्रंट-एंड या क्लाइंट-साइड वह कोड है जो उपयोगकर्ता को स्क्रीन पर सीधे टेक्स्ट के रंगों से लेकर बटन, चित्र और नेविगेशन मेनू तक हर चीज के लिए जिम्मेदार होता है। कुछ सामान्य कौशल और उपकरण जो फ्रंट-एंड डेवलपर्स द्वारा उपयोग किए जाते हैं, उन्हें नीचे सूचीबद्ध किया गया है -
- HTML/CSS/JavaScript
- सीएसएस प्रीप्रोसेसर
- Frameworks
- Libraries
- Git और Github
आम तौर पर, किसी एप्लिकेशन का बैक-एंड / सर्वर-साइड डेटाबेस के भीतर जानकारी के प्रबंधन और फ्रंट-एंड के लिए उस जानकारी को परोसने के लिए जिम्मेदार होता है। किसी वेबसाइट के बैक-एंड में सर्वर, एप्लिकेशन और डेटाबेस होते हैं। सामान्य तौर पर, इसमें वह सब कुछ शामिल होता है जो आपके ब्राउज़र को हिट करने से पहले होता है। बैक-एंड वेब डेवलपमेंट में आवश्यक उपकरण हैं -
Programming language - रूबी, पीएचपी, पायथन, आदि।
Database - MySQL, PostgreSQL, MongoDB, Oracle, आदि।
क्यों वेब विकास?
आज की दुनिया में, आपके व्यवसाय या कौशल को बढ़ावा देने और अपने विचारों को साझा करने के लिए कई विकल्प हैं। उनमें से कुछ वेबसाइटों के माध्यम से प्रचार कर रहे हैं, मार्केटप्लेस में मूल एप्लिकेशन आदि। व्यवसाय विकास के एक उपकरण के रूप में नई वेबसाइट बनाने की प्रवृत्ति तेजी से दुनिया भर में बढ़ रही है। लेकिन, हम में से कुछ इस बात से अनजान हो सकते हैं कि एक व्यवसाय के विकास में वेबसाइट का क्या महत्व है।
वर्तमान में खुले बाजार में अपनी उपस्थिति स्थापित करने के लिए कई स्टार्ट-अप संघर्ष कर रहे हैं। हालांकि, यह भी सच है कि उनमें से अधिकांश उतना लक्षित दर्शकों को प्राप्त करने में विफल होते हैं जितना वे चाहते हैं। एक प्राथमिक कारण जो उन्हें नीचे ला रहा है वह यह है कि वे उनके लिए व्यवसाय अर्जित करने के लिए एक पूर्ण फीचर विकसित वेबसाइट की क्षमता को कम आंकते हैं। व्यवसाय या किसी अन्य उद्देश्य के लिए वेबसाइट विकास काफी फलदायी साबित हो सकता है।
आइए हम कुछ महत्वपूर्ण कारणों पर ध्यान दें कि व्यावसायिक विकास के लिए वेबसाइट विकास क्यों महत्वपूर्ण है -
अपने दर्शकों तक पहुंचना
ऑनलाइन वेबसाइट व्यापक दर्शकों तक पहुंच सकती हैं और उन प्लेटफ़ॉर्म तक सीमित नहीं हैं जो देशी अनुप्रयोगों को बाधित करते हैं। दर्शकों या ग्राहकों के पास डेस्कटॉप / लैपटॉप से मोबाइल डिवाइस तक आसान पहुंच हो सकती है, क्योंकि वेबसाइटों में वेब ब्राउज़र के माध्यम से सामग्री प्रदर्शित करने की क्षमता होती है।
मूल एप्लिकेशन की तुलना में, वेब ब्राउज़िंग बहुत सरल है क्योंकि इसमें उपयोगकर्ताओं को अपने डिवाइस पर ऐप स्टोर तक पहुंचने या अपने ऐप को डाउनलोड करने की आवश्यकता नहीं होती है (जिसमें आपकी सामग्री तक पहुंचने में एक या अधिक प्रक्रिया शामिल हो सकती है)। आपके डेटा का वितरण वेब पर आधारित एप्लिकेशन के साथ बहुत अधिक लचीला और फुर्तीला है, क्योंकि इसमें ऐप स्टोर की आवश्यकताओं और पालन करने के लिए कोई सख्त प्रतिबंध नहीं हैं।
एक अन्य उपकरण जो वेब विकास के लिए बहुत उपयोगी है, जो आपके दर्शकों को लक्षित करने के लिए एसईओ तकनीकों का उपयोग करने की शक्ति है।
24/7 सुलभ
कंपनी के लिए एक भौतिक आउटलेट स्थापित करने के बजाय, यदि व्यवसाय का मालिक एक वेबसाइट को ऑनलाइन फोरम या इसी तरह के रूप में विकसित करता है, तो ऑनलाइन लिंक करने के लिए बड़े दर्शकों को प्राप्त करने का अच्छा मौका होगा। ऐसा इसलिए है, क्योंकि अधिकांश लोग पूरे दिन इंटरनेट से जुड़े रहते हैं।
आमतौर पर, लोग पहले ऑनलाइन जांच करने के लिए सबसे स्मार्ट तरीके से जाना पसंद करते हैं और फिर एक निर्णय लेते हैं। इसलिए यदि व्यवसाय स्वामी उत्पाद के सभी बुनियादी विवरणों को भरता है और ग्राहक को समय पर ढंग से उत्पाद प्राप्त करने का एक सुरक्षित तरीका बनाता है, तो लोग शारीरिक रूप से आउटलेट पर जाने के बजाय ऑनलाइन खरीदना पसंद करेंगे। इससे लोग दिन के सबसे विषम समय में भी इसका उपयोग कर सकते हैं।
सुविधा
एक पूरी तरह से कार्यात्मक वेबसाइट उन उपयोगकर्ताओं के लिए अधिक लाभ प्रदान करती है जहां वे हमेशा धुन कर सकते हैं और उनकी आवश्यकता की तलाश कर सकते हैं। आमतौर पर, यदि उपयोगकर्ता इसे ऑनलाइन प्राप्त करने का विकल्प रखते हैं, तो उपयोगकर्ता भौतिक रूप से स्टोर में जाने से बचते हैं। इसलिए, यदि आप एक स्मार्ट व्यवसायी हैं, तो आप केवल व्यवसाय अर्जित करने के लिए वेबसाइट पर अपने उत्पादों या अपने स्टोर के सभी विवरणों को रखना पसंद करेंगे, जो आप अन्यथा नहीं कर सकते हैं।
वैश्विक विपणन
एक ऑनलाइन वेबसाइट के साथ, आप सामाजिक मंचों से जुड़ सकते हैं और अपने उत्पाद / सेवा को दुनिया भर के विशाल दर्शकों तक पहुंचा सकते हैं। इसके साथ, आप नियमित रूप से लक्षित दर्शकों के बहुत अधिक पैरों के निशान हासिल करने के लिए सामाजिक मंचों पर अपने काम का विज्ञापन और साझा कर सकते हैं।
विश्वसनीय स्रोत
एक ऑनलाइन पोर्टल किसी भी कंपनी / संगठन के लिए सबसे भरोसेमंद मंच है। कभी-कभी आधिकारिक वेबसाइट भी अपने एकमात्र कार्यालय के रूप में कार्य कर सकती हैं। एक परिदृश्य पर विचार करें, जहां किसी कंपनी के भौतिक स्थान तक पहुंच प्राप्त करना आसान नहीं है। ऐसे में आप उनकी वेबसाइट पर ध्यान देकर इस चिंता को दूर कर सकते हैं।
संक्षेप में, एक वेबसाइट विकसित करके, आप कुछ क्लिकों द्वारा अपनी सेवाओं को बढ़ावा दे सकते हैं और दुनिया के विभिन्न हिस्सों से उपभोक्ताओं का ध्यान आकर्षित कर सकते हैं। एक कंपनी की वेबसाइट न केवल कम समय में बल्कि बहुत बड़े दर्शकों के साथ व्यापार हासिल करने के लिए उल्लेखनीय साबित हो सकती है।
पायथॉन वेब और एप्लिकेशन डेवलपर्स के बीच सबसे स्वीकार्य भाषाओं में से एक है क्योंकि इसकी दक्षता और पठनीयता पर जोर दिया गया है। कई उत्कृष्ट पायथन वेब ढांचे हैं, जिनमें से प्रत्येक की अपनी विशिष्टताएं और विशेषताएं हैं।
Django
यहां, हम Django ढांचे के कुछ आवश्यक विवरण और विशेषताओं को रेखांकित करेंगे।
Category - Django फुल-स्टैक पायथन फ्रेमवर्क के अंतर्गत आता है।
Release - नवीनतम रिलीज - 2.1 संस्करण, आमतौर पर इस्तेमाल किया रिलीज - 1.8, 1.6 संस्करण।
About- अनुभवी डेवलपर्स द्वारा निर्मित, Django एक उच्च स्तरीय पायथन वेब फ्रेमवर्क है जो तीव्र, स्वच्छ और व्यावहारिक डिजाइन विकास की अनुमति देता है। Django वेब विकास की बहुत सारी जटिलताओं को संभालता है, इसलिए आप पहिया को सुदृढ़ करने की आवश्यकता के बिना अपने ऐप को लिखने पर ध्यान केंद्रित कर सकते हैं। यह स्वतंत्र और खुला स्रोत है।
डेटाबेस तालिका में वस्तुओं को मैप करने के लिए, Django ORM का उपयोग करता है और उसी का उपयोग एक डेटाबेस से दूसरे में स्थानांतरित करने के लिए किया जाता है।
यह ज्यादातर सभी महत्वपूर्ण डेटाबेस जैसे Oracle, MySQL, PostgreSQL, SQLite, आदि के साथ काम करता है।
उद्योग में कई वेबसाइटें हैं जो बैकएंड डेवलपमेंट के लिए प्राथमिक ढांचे के रूप में Django का उपयोग करती हैं।
Django की विशेषताएं
इस पायथन वेब ढांचे की कुछ अनुकरणीय विशेषताएं हैं -
- URL रूटिंग
- Authentication
- डेटाबेस स्कीमा माइग्रेशन
- ORM (ऑब्जेक्ट-रिलेशनल मैपर)
- टेम्पलेट इंजन
Django ढांचे के लिए आधिकारिक वेबसाइट है -https://www.djangoproject.com/
फ्लास्क
Category - फ्लास्क नॉन फुल-स्टैक फ्रेमवर्क से संबंधित है।
Release - 2018-05-02 को 1.0.2 जारी किया गया
About- इसे एक माइक्रो-फ्रेमवर्क के रूप में वर्गीकृत किया गया है क्योंकि हमें किसी विशेष लाइब्रेरी या टूल की आवश्यकता नहीं है। इसका कोई रूप सत्यापन या डेटाबेस अमूर्त परत या कोई अन्य घटक नहीं है, जहां पहले से मौजूद तृतीय पक्ष पुस्तकालय सामान्य कार्य प्रदान करते हैं। हालाँकि, फ्लास्क कई एक्सटेंशनों का समर्थन करते हैं, जो अनुप्रयोग सुविधाओं को बढ़ाते हैं जैसे कि वे फ्लास्क में ही लागू किए गए थे। ऑब्जेक्ट-रिलेशनल मैपर्स के लिए एक्सटेंशन मौजूद हैं, फॉर्म वैलिडेशन, अपलोड हैंडलिंग, विभिन्न ओपन ऑथेंटिकेशन टेक्नोलॉजी और कई सामान्य फ्रेमवर्क संबंधित टूल।
फ्लास्क की विशेषताएं
- इकाई परीक्षण के लिए एकीकृत समर्थन
- शेष अनुरोध प्रेषण
- विकास सर्वर और डीबगर होता है
- जिनजा 2 टेम्प्लेटिंग का उपयोग करता है
- सुरक्षित कुकीज़ के लिए समर्थन
- Unicode-based
- 100% डब्ल्यूएसजीआई 1.0 अनुपालन
- व्यापक प्रलेखन
- Google ऐप इंजन संगतता
- वांछित सुविधाओं को बढ़ाने के लिए उपलब्ध एक्सटेंशन
web2py
Category - Web2py पूर्ण-स्टैक फ्रेमवर्क परिवार से संबंधित है।
Release - 2.17.1, 2018-08-06 को जारी किया गया
About- पायथन 2.6, 2.7 पायथन 3.x संस्करण। आगे की निर्भरता के साथ, यह अपने आप में एक पूर्ण पैकेज है। विकास, डेटाबेस प्रशासन, डिबगिंग, परिनियोजन, परीक्षण और अनुप्रयोगों का रखरखाव सभी वेब इंटरफ़ेस के माध्यम से किया जा सकता है, लेकिन आम तौर पर इसकी आवश्यकता नहीं होती है। यह एक स्केलेबल ओपन सोर्स फ्रेमवर्क है जो कोड एडिटर, वन-क्लिक तैनाती और डीबगर के साथ-साथ अपने स्वयं के वेब-आधारित आईडीई के साथ आता है।
Web2py की विशेषताएं
यह ढांचा कई विकासशील उपकरणों और अंतर्निहित सुविधाओं के साथ आता है जो डेवलपर्स के लिए जटिलता की परेशानी को खत्म करते हैं।
स्थापना और कॉन्फ़िगरेशन नहीं होने से इसे चलाना आसान है।
लगभग सभी प्रमुख ऑपरेटिंग सिस्टम का समर्थन करता है, जैसे विंडोज, यूनिक्स / लिनक्स, मैक, Google ऐप इंजन और लगभग सभी वेब होस्टिंग प्लेटफ़ॉर्म पायथन 2.7 / 3.5 / 3.6 / संस्करण के माध्यम से।
MySQL, MSSQL, IBM DB2, Informix, Ingres, MongoDB, SQLite, PostgreSQL, Sybase, Oracle और Google App Engine के साथ संचार करना आसान है।
यह क्रॉस साइट स्क्रिप्टिंग, इंजेक्शन फ्लॉस और दुर्भावनापूर्ण फ़ाइल निष्पादन सहित सबसे आम प्रकार की कमजोरियों को रोकता है।
त्रुटि ट्रैकिंग और अंतर्राष्ट्रीयकरण का समर्थन करता है।
एकाधिक प्रोटोकॉल पठनीयता।
सफल सॉफ्टवेयर इंजीनियरिंग प्रथाओं को लागू करता है जो कोड को पढ़ने और बनाए रखने में आसान बनाता है।
बैकवर्ड संगतता के माध्यम से उपयोगकर्ता-उन्मुख प्रगति सुनिश्चित करें।
पिरामिड
Category - पिरामिड एक नॉन-फुल स्टैक फ्रेमवर्क है
Release - 1.9.2, 2018-04-23 को जारी किया गया
About- पिरामिड एक छोटा, तेज, डाउन-टू-अर्थ पायथन वेब फ्रेमवर्क है। इसे पाइलन्स प्रोजेक्ट के हिस्से के रूप में विकसित किया गया है। यह बीएसडी जैसे लाइसेंस के तहत लाइसेंस प्राप्त है। यह वास्तविक दुनिया वेब अनुप्रयोग विकास और तैनाती को और अधिक मज़ेदार, अधिक पूर्वानुमान और अधिक उत्पादक बनाता है।
पिरामिड की विशेषताएं
पायथन पिरामिड निम्नलिखित विशेषताओं वाला एक खुला स्रोत है -
Simplicity - कोई भी इसके बारे में कोई पूर्व जानकारी के बिना इसके साथ काम करना शुरू कर सकता है।
Minimalism - बॉक्स से बाहर, पिरामिड केवल कुछ महत्वपूर्ण उपकरणों के साथ आता है, जो लगभग हर वेब एप्लिकेशन के लिए आवश्यक होते हैं, यह सुरक्षा और जावास्क्रिप्ट या सीएसएस जैसी स्थैतिक संपत्ति या कोड के लिए URL संलग्न करना हो सकता है।
Documentation - विशेष और तारीख प्रलेखन तक शामिल है।
Speed - बहुत तेज और सटीक।
Reliability- इसे विकसित किया गया है, यह ध्यान में रखते हुए कि यह रूढ़िवादी है और पूरी तरह से परीक्षण किया गया है। यदि ठीक से परीक्षण नहीं किया गया, तो इसे टूटा हुआ माना जाएगा।
Openness - यह एक अनुमेय और खुले लाइसेंस के साथ बेचा जाता है।
पानी का छींटा
Category - डैश ढांचा "अन्य" पायथन वेब फ्रेमवर्क से संबंधित है।
Release - 0.24.1, कोर डैश बैकएंड।
About- इंटरैक्टिव वेब-आधारित विज़ुअलाइज़ेशन बनाने के लिए एक ओपन सोर्स लाइब्रेरी के रूप में डैश। प्लॉटली टीम ने डैश बनाया - एक खुला स्रोत ढांचा जो फ्लास्क, रिएक्ट.जेएस और प्लॉटली.जेएस का लाभ उठाता है ताकि कस्टम डेटा विज़ुअलाइज़ेशन ऐप का निर्माण किया जा सके। इस पुस्तकालय का मुख्य आकर्षण यह है कि आप केवल पायथन कोड के माध्यम से अत्यधिक संवादात्मक वेब अनुप्रयोग बना सकते हैं। डेटा वैज्ञानिक डैश फ्रेमवर्क को पसंद करते हैं, विशेष रूप से उन सभी को जो वेब विकास से कम परिचित हैं।
डैश के साथ, डेवलपर्स को सभी कॉन्फ़िगर करने योग्य गुणों और अंतर्निहित फ्लास्क उदाहरण तक पहुंच मिलती है। डैश फ्रेमवर्क का उपयोग करके विकसित किए गए एप्लिकेशन को सर्वर पर तैनात किया जा सकता है और अंततः वेब ब्राउज़र में प्रदान किया जाता है।
डैश एप्लिकेशन स्वाभाविक रूप से क्रॉस-प्लेटफ़ॉर्म (लिनक्स / विन / मैक) और मोबाइल के अनुकूल हैं और अनुप्रयोगों की क्षमताओं को फ्लास्क प्लगइन्स के समृद्ध सेट द्वारा बढ़ाया जा सकता है।
पानी का छींटा
- विन्यास गुण और फ्लास्क उदाहरण के लिए पहुँच प्रदान करता है
- फ्लैश प्लगइन्स के माध्यम से, हम डैश एप्लिकेशन की क्षमताओं को बढ़ा सकते हैं
- Mobile-ready
इस अध्याय में, हम Django फ्रेमवर्क के बारे में विस्तार से चर्चा करेंगे।
Django एक MVT वेब फ्रेमवर्क है जिसका उपयोग वेब एप्लिकेशन बनाने के लिए किया जाता है। विशाल Django वेब-फ्रेम इतने "बैटरी शामिल" के साथ आता है कि डेवलपर्स अक्सर चकित हो जाते हैं कि कैसे सब कुछ एक साथ काम करने का प्रबंधन करता है। इतनी सारी बैटरियों को जोड़ने के पीछे सिद्धांत यह है कि अलग लाइब्रेरी के रूप में बाद में जोड़ने के बजाय फ्रेमवर्क में ही आम वेब फंक्शंस हों।
Django ढांचे की लोकप्रियता के पीछे मुख्य कारणों में से एक विशाल Django समुदाय है। यह समुदाय इतना विशाल है कि एक अलग वेबसाइट इसके लिए समर्पित थी, जहां सभी कोनों के डेवलपर्स ने प्रमाणीकरण, प्राधिकरण, पूर्ण-विकसित Django संचालित CMS सिस्टम, ई-कॉमर्स ऐड-ऑन और सहित तृतीय-पक्ष पैकेज विकसित किए। एक उच्च संभावना है कि आप जो विकसित करने की कोशिश कर रहे हैं वह पहले से ही किसी के द्वारा विकसित किया गया है और आपको इसे केवल अपने प्रोजेक्ट में खींचने की आवश्यकता है।
आपको Django का उपयोग क्यों करना चाहिए?
Django इस तरह से डिज़ाइन किया गया है जो डेवलपर्स को वेबसाइटों को तेज, स्वच्छ और व्यावहारिक डिजाइन के साथ विकसित करने के लिए प्रोत्साहित करता है। चीजों को प्राप्त करने के लिए Django का व्यावहारिक दृष्टिकोण वह है जहां यह भीड़ से बाहर खड़ा है।
यदि आप सोशल मीडिया वेबसाइट जैसे एक उच्च अनुकूलन योग्य ऐप बनाने की योजना बना रहे हैं, तो Django पर विचार करने के लिए सबसे अच्छे ढांचे में से एक है। Django ताकत उपयोगकर्ताओं या विभिन्न प्रकार के मीडिया को साझा करने की क्षमता के बीच बातचीत में निहित है। Django के महान लाभ में से एक इसकी बड़ी समुदाय-आधारित सहायता का उपयोग करने की क्षमता है जो आपको अपने अनुप्रयोगों में प्लगइन्स का उपयोग करने के लिए तैयार उच्च अनुकूलन योग्य तृतीय-पक्ष देता है।
वेब विकास के लिए Django चुनने के लिए शीर्ष दस कारण नीचे दिए गए हैं -
अजगर
पाइथन अपने सरल भाषा निर्माण, प्रवाह संरचना और आसान वाक्य रचना के कारण सीखने के लिए सबसे आसान प्रोग्रामिंग भाषाओं में से एक है। यह बहुमुखी है और कई उपकरणों में एम्बेडेड वेबसाइटों, डेस्कटॉप अनुप्रयोगों और मोबाइल अनुप्रयोगों को चलाता है और एक लोकप्रिय स्क्रिप्टिंग भाषा के रूप में अन्य अनुप्रयोगों में उपयोग किया जाता है।
बैटरियों में शामिल हैं
Django आम लाइब्रेरियों के साथ आता है जो URL राउटिंग, ऑथेंटिकेशन, ऑब्जेक्ट-रिलेशनल मैपर (ORM), एक टेम्प्लेटिंग सिस्टम और db-स्कीमा माइग्रेशन जैसे कॉमन फंक्शंस बनाने के लिए आवश्यक हैं।
बिल्ट-इन एडमिन
Django में एक अंतर्निर्मित व्यवस्थापन इंटरफ़ेस है जो आपको अपने मॉडल, उपयोगकर्ता / समूह अनुमतियाँ और उपयोगकर्ताओं को प्रबंधित करने की अनुमति देता है। जगह में मॉडल इंटरफेस के साथ, सभी लेकिन उन्नत डेटाबेस कार्यों के लिए एक अलग डेटाबेस प्रशासन कार्यक्रम की आवश्यकता नहीं है।
अपने रास्ते में नहीं मिलता है
Django एप्लिकेशन बनाना कोई बॉयलरप्लेट और कोई अनावश्यक फ़ंक्शन नहीं जोड़ता है। कोई अनिवार्य आयात, तृतीय-पक्ष लाइब्रेरी और कोई XML कॉन्फ़िगरेशन फ़ाइल नहीं है।
मापनीय
Django MVC डिजाइन पैटर्न पर आधारित है। इसका अर्थ है कि db (डेटाबेस), बैक-एंड और फ्रंट-एंड कोड जैसी सभी इकाइयाँ व्यक्तिगत इकाई हैं। Django हमें उन स्थिर मीडिया से कोड को अलग करने की अनुमति देता है जिनमें चित्र, फाइलें, CSS और जावास्क्रिप्ट शामिल हैं जो आपकी साइट बनाते हैं।
Django वेब सर्वर, कैशिंग, प्रदर्शन प्रबंधन, क्लस्टरिंग और संतुलन के लिए तृतीय-पक्ष पुस्तकालयों की एक पूरी सूची का समर्थन करता है। Django द्वारा प्रदान किए जाने वाले लाभों में से एक प्रमुख ईमेल और मैसेजिंग अनुप्रयोगों और सेवाओं जैसे कि ReST और OAuth का समर्थन है।
लड़ाई का परीक्षण किया
2005 में Django पहली बार खुला था। 12 साल की वृद्धि के बाद, Django अब न केवल समाचार प्रकाशन वेबसाइटों को चलाता है, बल्कि Pinterest, Instagram, Disqus, Bitbucket, EventBrite और Zapier जैसे सभी प्रमुख वैश्विक उद्यमों का हिस्सा है। यह इसके साथ काम करने के लिए एक मजबूत और विश्वसनीय वेब फ्रेमवर्क बनाता है।
विशाल पैकेज का समर्थन
इसके बड़े सामुदायिक समर्थन और विशाल डेवलपर्स नेटवर्क की वजह से, इस बात की बहुत अधिक संभावना है कि आप जो भी करने का इरादा रखते हैं वह पहले हो सकता है। डेवलपर्स के बड़े अंतर्राष्ट्रीय समुदाय अपनी परियोजनाओं को ओपन-सोर्स पैकेज के रूप में जारी करके समुदाय में योगदान करते हैं।
इन परियोजनाओं में से एक ऐसी ही रिपॉजिटरी Django पैकेज साइट है। वर्तमान में, Django पैकेज 3400 से अधिक पुन: प्रयोज्य Django एप्लिकेशन, साइटों और उपकरणों की सूची हमारे Django परियोजनाओं में उपयोग करने के लिए।
सक्रिय रूप से विकसित
ओपन सोर्स प्रोजेक्ट से जुड़े सबसे बड़े जोखिमों में से एक इसकी स्थिरता है। यदि यह लंबे समय तक रहता है तो हम निश्चित नहीं हो सकते।
Django के साथ ऐसा कोई जोखिम नहीं है क्योंकि यह 12 साल पुराना है। इसके लगातार रिलीज़, नए / बेहतर संस्करण और सक्रिय समुदाय हर दिन स्वैच्छिक योगदानकर्ताओं की एक बड़ी कोर टीम के साथ बढ़ रहे हैं जो हर दिन कोड बेस को बनाए और सुधारते हैं।
स्थिर रिलीज
Django जैसी ओपन-सोर्स सॉफ्टवेयर परियोजनाएं, कई मामलों में, सक्रिय रूप से विकसित और प्रतिस्पर्धी मालिकाना सॉफ़्टवेयर की तुलना में अधिक सुरक्षित हैं क्योंकि कई डेवलपर्स हर दिन इसे विकसित और परीक्षण कर रहे हैं। हालाँकि, एक ओपन-सोर्स सॉफ़्टवेयर प्रोजेक्ट की खामी व्यावसायिक रूप से व्यवहार्य विकास के लिए एक स्थिर कोडबेस की अनुपस्थिति है।
Django में, हमारे पास सॉफ़्टवेयर का दीर्घकालिक समर्थन (LTS) संस्करण और एक परिभाषित रिलीज़ प्रक्रिया है जैसा कि नीचे दी गई छवि में दिखाया गया है -
प्रथम श्रेणी का प्रलेखन
पहले रिलीज से, Django डेवलपर्स ने सुनिश्चित किया कि उचित व्यापक दस्तावेज़ उपलब्ध होने चाहिए और ट्यूटोरियल आसानी से समझ में आ सकते हैं।
कौन Django का उपयोग कर रहा है?
Django की अनूठी ताकत के कारण, कई लोकप्रिय वेबसाइट हैं जो Django ढांचे के शीर्ष पर पायथन के साथ बनाई गई हैं। नीचे कुछ प्रमुख साइटें हैं जो पूरी तरह से या आंशिक रूप से Django पर आधारित हैं।
Disqus
यह विश्व स्तर पर सबसे पसंदीदा ब्लॉग टिप्पणी-होस्टिंग साइटों में से एक है। सबसे लोकप्रिय सीएमएस (कंटेंट मैनेजमेंट सिस्टम) जैसे वर्डप्रेस और कई अन्य के साथ डिस्कस के माध्यम से एकीकृत करना आसान है। 50 मिलियन से अधिक के उपयोगकर्ता-आधार को संभालने के बाद, Django साइट मालिकों को उनके समुदायों तक पहुंचने के लिए संतुष्ट करने में सक्षम है।
प्याज
प्याज वेबसाइट जो अपने व्यंग्य अखबार के लिए एक ऑनलाइन स्थल प्रदान करती है, Django इसके लिए रूपरेखा प्रदान करता है।
बिट बकेट
Bitbucket GitHub की तरह है, एक संस्करण नियंत्रण रिपॉजिटरी होस्टिंग सेवा है। Bitbucket और GitHub के बीच एकमात्र अंतर यह है कि Bitbucket मर्क्यूरियल रिपॉजिटरी को होस्ट करता है जबकि GitHub git रिपॉजिटरी को होस्ट करता है। जैसा कि लाखों उपयोगकर्ता Bitbucket के साथ जुड़े हुए हैं, और सभी सेवाएँ जो bitbucket प्रदान करती हैं (जैसे रेपो बनाएं, अपना कोड धक्का दें, सहयोगी जोड़ें, कमिट करें, अनुरोध करें, आदि) स्थिर होना चाहिए। बिटकॉइन साइट को चलाने के लिए जिओगो जिम्मेदार है।
इंस्टाग्राम एक सोशल नेटवर्किंग ऐप है जो विशेष रूप से उन लोगों के लिए बनाया गया है जो अपने सभी दोस्तों को फोटो और वीडियो साझा करना पसंद करते हैं। वर्तमान में इंस्टाग्राम पर बहुत सारे सेलिब्रिटी हैं ताकि अपने प्रशंसकों के करीब रहें। इंस्टाग्राम को भी Django का फ्रेमवर्क चला रहा है।
मोज़िला फ़ायरफ़ॉक्स
Google Chrome मोज़िला ब्राउज़र के बाद दुनिया में दूसरा सबसे व्यापक रूप से उपयोग किया जाने वाला ब्राउज़र है। अब मोजिला का हेल्प पेज Django फ्रेमवर्क के साथ बनाया गया है।
दुनिया भर में लाखों उपयोगकर्ता Pinterest से अपने नए विचारों और प्रेरणा की खोज करते हैं। Pinterest इसे चलाने के लिए Django ढांचे (अपनी आवश्यकता के अनुसार संशोधन) का उपयोग कर रहा है।
नासा
नेशनल एरोनॉटिक्स एंड स्पेस एडमिनिस्ट्रेशन की आधिकारिक वेबसाइट लाखों उपयोगकर्ताओं द्वारा प्रीमियर एजेंसी द्वारा प्रदान की जाने वाली खबरों, छवियों, वीडियो और पॉडकास्ट को देखने और जांचने के लिए एक जगह है। Django आधिकारिक नासा वेबसाइट के कुछ विशिष्ट भागों को विकसित करता है।
द वाशिंगटन पोस्ट
अगर दुनिया में एक प्रभावशाली अखबार है, तो यह निश्चित रूप से वाशिंगटन पोस्ट है। वाशिंगटन पोस्ट की वेबसाइट उनके दैनिक पत्र के साथ आने के लिए बेहद लोकप्रिय ऑनलाइन समाचार स्रोत है। इसके विशाल दृश्य और यातायात को आसानी से Django वेब फ्रेमवर्क द्वारा नियंत्रित किया गया है।
Reddit उपहार
व्यापक रूप से लोकप्रिय Reddit वेबसाइट ने Reddit उपहार नामक एक ऑनलाइन, अनाम उपहार विनिमय और मीटअप प्लेटफ़ॉर्म लॉन्च किया है। साइट दुनिया भर के उपयोगकर्ताओं को जोड़ती है और उनके बीच उपहार विनिमय की सुविधा प्रदान करती है। Django वेब फ्रेमवर्क अपनी कार्यक्षमता को शक्ति देता है।
Prezi
Prezi Microsoft PowerPoint का एक क्लाउड आधारित विकल्प है जो Django ढांचे पर बनाया गया है। साइट एक आभासी कैनवास प्रदान करती है जिसे हेरफेर और ज़ूम इन और आउट किया जा सकता है। यह व्यक्तिगत स्लाइड के बजाय प्रस्तुति का संपूर्ण दृश्य प्रदान करता है।
एक Django परियोजना और एप्लिकेशन इंस्टॉल करना और बनाना
Django स्थापित करने से पहले, हमें यह सुनिश्चित करना होगा कि पायथन स्थापित है। मान लें कि आप virtualenv का उपयोग कर रहे हैं, एक सरल पाइप स्थापित django को पर्याप्त होना चाहिए।
आभासी वातावरण और Django स्थापित करना
नीचे आपके विंडोज़ वातावरण में आभासी वातावरण और Django स्थापित करने की प्रक्रिया है -
यह सत्यापित करने के लिए कि क्या Django ठीक से स्थापित है, नीचे दिया गया कोड लिखें -
Django प्रोजेक्ट बनाना
एक बार स्थापना पूर्ण हो जाने के बाद, हमें एक Django परियोजना बनाने की आवश्यकता है।
अपनी विंडोज़ मशीन में नीचे दिए गए कमांड को चलाने से निम्नलिखित django प्रोजेक्ट बन जाएगा -
django-admin startproject my_project_name
टाइपिंग डीआईआर एक नई फ़ाइल और एक नई निर्देशिका दिखाएगी जैसा कि ऊपर दिखाया गया है।
manage.py- manage.py एक कमांड-लाइन-एक्ज़ीक्यूटेबल पायथन फाइल है, जो django-admin के चारों ओर एक आवरण है। यह हमारी परियोजना को प्रबंधित करने में मदद करता है जो इसके नाम से निहित है।
इसके साथ, इसने एक निर्देशिका बनाई, जिसे कहा जाता है, myFirstDjangoProjectmyFirstDjangoProject के अंदर जो हमारी परियोजना के लिए कॉन्फ़िगरेशन रूट का प्रतिनिधित्व करता है। आइए हम इसमें बहुत गहराई से खोजबीन करें।
Django का विन्यास
MyFirstDjangoProject निर्देशिका "कॉन्फ़िगरेशन रूट" को कॉल करके, हमारा मतलब है कि यह निर्देशिका आम तौर पर हमारे नैनो प्रोजेक्ट को कॉन्फ़िगर करने के लिए आवश्यक फाइलें रखती है। इस निर्देशिका के बाहर बहुत कुछ पूरी तरह से "व्यापार तर्क" पर केंद्रित होगा जो परियोजना के मॉडल, विचार, मार्गों आदि से जुड़ा है। सभी बिंदु जो परियोजना को एक साथ जोड़ते हैं, यहां नेतृत्व करेंगे।
__init__.py - यह खाली है और निर्देशिका को एक आयात योग्य पायथन पैकेज में बदल देता है।
settings.py - जैसा कि नाम से ही पता चलता है, यह वह जगह है जहाँ सबसे अधिक कॉन्फ़िगरेशन आइटम सेट किए जाएंगे।
urls.py - यूआरएल urls.py के साथ सेट किए गए हैं। इसके साथ, हमें इस फ़ाइल में प्रोजेक्ट के लिए प्रत्येक URL को स्पष्ट रूप से लिखना नहीं है। हालाँकि, हमें Django को बताना होगा कि URL कहाँ घोषित किए गए हैं (यानी, हमें urls.py में अन्य URL को लिंक करना होगा)।
Wsgi.py - यह उत्पादन में एप्लिकेशन की मदद करने के लिए है और फ्लास्क, टॉर्नेडो, पिरामिड जैसे अन्य अनुप्रयोगों के समान है जो कुछ "ऐप" ऑब्जेक्ट को उजागर करता है।
सेटिंग करना
सेटिंग्स के अंदर एक नज़र रखने पर, थिंकपैड अपने काफी आकार को प्रकट करेगा - और ये सिर्फ चूक हैं। अन्य चीजें जो हमें ध्यान रखने की जरूरत हैं वे हैं स्थिर फाइलें, डेटाबेस, मीडिया फाइलें, क्लाउड इंटीग्रेशन या अन्य दर्जनों तरीके जो एक Django प्रोजेक्ट को कॉन्फ़िगर किया जा सकता है। आइए सेटिंगफ्रेम फाइल में बताए गए कुछ बिंदुओं को समझते हैं -
BASE_DIR- यह फ़ाइलों का पता लगाने के लिए सहायक है। सेटिंग फ़ाइल के अंदर, BASE_DIR पैरामीटर आधार निर्देशिका के लिए निरपेक्ष पथ सेट करता है।
SECRET_KEY- इसका उपयोग हैश बनाने के लिए किया जाता है। सामान्य तौर पर, हमने कुकीज, सेशन, सीएसआरएफ प्रोटेक्शन और ऑर्किटेक्ट टोकन के लिए secret_key का इस्तेमाल किया।
DEBUG - हम इसे या तो विकास या उत्पादन मोड में चलाने के लिए सेट कर सकते हैं।
ALLOWED_HOSTS- हम उन होस्टनामों की सूची प्रदान करते हैं जिनके माध्यम से हमारे आवेदन को परोसा जा रहा है। विकास मोड में, यह सेट करने के लिए वैकल्पिक है; हालाँकि, उत्पादन मशीन में, हमें अपना Django प्रोजेक्ट सेट करना होगा।
INSTALLED_APPS- यह Django "एप्लिकेशन" की सूची है जो वर्तमान में हमारे Django प्रोजेक्ट में स्थापित और चल रही है। इन-बिल्ट Django छह स्थापित ऐप निम्नानुसार प्रदान करता है -
'django.contrib.admin'
'django.contrib.auth'
django.contrib.
django.contrib.sessions
django.contrib.messages
django.contrib.staticfiles
MIDDLEWARE- यह हमारे Django प्रोजेक्ट को चलाने में मदद करता है। यह एक अजगर वर्ग है जो django request / response processing में हुक करता है।
TEMPLATES- यह परिभाषित करता है कि दस्तावेज़ को दृश्यपटल में कैसे प्रदर्शित किया जाना चाहिए। Django टेम्प्लेट का उपयोग किसी भी पाठ-आधारित प्रारूप के निर्माण के लिए किया जाता है।
WSGI_APPLICATION- हमारे द्वारा सेट किए गए किसी भी सर्वर को यह जानना होगा कि डब्ल्यूएसजीआई फाइल कहां है। यदि आप बाहरी सर्वर का उपयोग कर रहे हैं, तो यह अपनी सेटिंग्स में दिखेगा। डिफ़ॉल्ट रूप से, यह wsgi.py में वस्तुओं को इंगित करता है।
DATABASES- यह डेटाबेस के लिए सेट है हमारे Django परियोजना वर्तमान में पहुँच रहा है। डिफ़ॉल्ट डेटाबेस सेट करना अनिवार्य है। यदि हम अपनी पसंद का डेटाबेस सेट करते हैं, तो हमें डेटाबेस से संबंधित कुछ चीजों का उल्लेख करना होगा जैसे - HOST, USER, PASSWORD, PORT, डेटाबेस NAME और उपयुक्त इंजन।
STATIC_URL- यह STATIC_ROOT में स्थित स्थिर फ़ाइलों का जिक्र करते समय उपयोग करने वाला URL है। डिफ़ॉल्ट रूप से, यह कोई नहीं है।
हालाँकि, हमें स्थैतिक फ़ाइलों के लिए एक पथ जोड़ने की आवश्यकता हो सकती है। फ़ाइल के अंत में नीचे जाएं, और बस STATIC_URL प्रविष्टि के नीचे, STATIC_ROOT नामक एक नया जोड़ें जैसा कि नीचे दिखाया गया है -
myFirstDjangoProject/settings.py
STATIC_URL = '/ स्थिर /'
STATIC_ROOT = os.path.join (BASE_DIR, 'स्थिर')
एक डेटाबेस की स्थापना
बहुत सारे अलग-अलग डेटाबेस सॉफ्टवेयर हैं जो आपकी साइट के लिए तारीख स्टोर कर सकते हैं। हम डिफ़ॉल्ट एक, sqlite3 का उपयोग करेंगे।
यह आपके नीचे दिए गए भाग में पहले से ही सेट है myFirstDjangoProject/settings.py -
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
हमारे ब्लॉग के लिए एक डेटाबेस बनाने के लिए, हम कंसोल में निम्नलिखित रन करते हैं - python manage.py migrate (हमें myFirstDjangoProject डायरेक्टरी में होना चाहिए जिसमें मैनेजमेन्ट फ़ाइल है।
यदि आपको सब कुछ ठीक लगे तो आपको निम्न आउटपुट मिलेंगे -
वेब सर्वर शुरू करना
आपको उस निर्देशिका में रहने की आवश्यकता है जिसमें प्रबंधक फ़ाइल है। कंसोल में, हम अजगर प्रबंधन को चलाने का प्रयास करके वेब सर्वर शुरू कर सकते हैं:
अब आपको बस इतना करना है कि आपकी वेबसाइट चल रही है। अपना ब्राउज़र खोलें (फ़ायरफ़ॉक्स, क्रोम, सफारी, इंटरनेट एक्सप्लोरर या जो भी आप उपयोग करते हैं) और यह पता दर्ज करें -
http://127.0.0.1:8000/
या
http://localhost:8000/ # जैसा कि हमारे वेबसर्वर हमारे स्थानीय मशीन में ही चल रहे हैं।
बधाई हो! आपने अभी अपनी पहली वेबसाइट बनाई है और इसे वेब सर्वर का उपयोग करके चलाया है!
जबकि वेब सर्वर चल रहा है, आपको अतिरिक्त कमांड दर्ज करने के लिए एक नया कमांड-लाइन प्रॉम्प्ट दिखाई नहीं देगा। टर्मिनल अगले पाठ को स्वीकार करेगा लेकिन नए आदेशों पर अमल नहीं करेगा। यह इसलिए है क्योंकि आने वाले अनुरोधों को सुनने के लिए वेब सर्वर लगातार चलता रहता है।
Django मॉडल
हम एक Django मॉडल बनाने की कोशिश कर रहे हैं जो हमारे ब्लॉग की सभी पोस्टों को संग्रहीत करेगा। लेकिन यह सुनिश्चित करने के लिए कि यह काम करता है, हमें वस्तुओं के बारे में जानने की जरूरत है।
वस्तुओं
वस्तुएं गुणों और कार्यों का एक संग्रह है। इसे एक उदाहरण से समझते हैं। मान लीजिए कि हम एक बिल्ली को मॉडल बनाना चाहते हैं, हम बिल्ली नामक एक वस्तु बनाएंगे जिसमें रंग, आयु, मनोदशा (अच्छी / बुरी / नींद) और मालिक जैसे गुण हैं।
फिर बिल्ली के पास कुछ क्रियाएं होती हैं: मवाद, खरोंच या चारा।
Cat
--------
color
age
mood
owner
purr()
scratch()
feed(cat_food)
CatFood
--------
taste
इसलिए मूल रूप से हम गुणों के साथ कोड में वास्तविक चीजों का वर्णन करने की कोशिश कर रहे हैं (जिसे ऑब्जेक्ट गुण कहा जाता है) और क्रियाएं (जिन्हें विधि कहा जाता है)।
जैसा कि हम एक ब्लॉग का निर्माण कर रहे हैं, हमें कुछ पाठ सामग्री और शीर्षक की आवश्यकता है। लेखक का नाम, सृजन की तिथि और प्रकाशन की तिथि भी होना आवश्यक है।
तो हमारे ब्लॉग में निम्नलिखित वस्तुएं होंगी -
Post
--------
title
text
author
created_date
published_date
साथ ही हमें कुछ ऐसी विधि की आवश्यकता है जो उस पोस्ट को प्रकाशित करे। जैसा कि हम अब जानते हैं कि एक वस्तु क्या है, हम अपने ब्लॉग पोस्ट के लिए एक Django मॉडल बना सकते हैं।
एक मॉडल Django में एक विशेष प्रकार की वस्तु है और डेटाबेस में सहेजी जाती है। हम अपना डेटा SQLite डेटाबेस में संग्रहीत करेंगे।
एक एप्लिकेशन बनाना
सब कुछ स्पष्ट रखने के लिए, हम अपने प्रोजेक्ट के अंदर एक अलग एप्लिकेशन बनाएंगे। नीचे, हम सरल कमांड के नीचे चलकर एक ब्लॉग वेब एप्लिकेशन बनाने का प्रयास करेंगे।
अब हम देखेंगे कि एक नई myBlog निर्देशिका बनाई गई है और इसमें अभी कई फाइलें हैं। हमारी परियोजना की निर्देशिका और फाइलें इस प्रकार होनी चाहिए -
एप्लिकेशन बनाने के बाद, हमें इसका उपयोग करने के लिए Django को भी बताना होगा। हम फ़ाइल myFirstDjangoProject / settings.py में करते हैं।
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'myBlog',
]
एक ब्लॉग पोस्ट मॉडल बनाना
में myBlog/models.py फ़ाइल, हम मॉडल नामक सभी वस्तुओं को परिभाषित करते हैं - यह एक ऐसी जगह है जिसमें हम अपने ब्लॉग पोस्ट को परिभाषित करेंगे।
आइए, myBlog / model.py खोलें, इसमें से सब कुछ हटा दें, और निम्नानुसार कोड लिखें -
सबसे पहले, हम कुछ फ़ंक्शंस को दूसरी फ़ाइलों से आयात या आयात करके कॉल करते हैं। तो इसके साथ, हर फाइल में समान चीजों को कॉपी और पेस्ट करने के बजाय, हम कुछ हिस्सों को शामिल कर सकते हैंfrom and import।
class Post(models.Model) - यह रेखा हमारे मॉडल को परिभाषित करती है (यह एक वस्तु है)।
क्लास एक विशेष कीवर्ड है जो इंगित करता है कि हम एक ऑब्जेक्ट को परिभाषित कर रहे हैं।
पोस्ट हमारे मॉडल का नाम है। हमेशा एक बड़े अक्षर के साथ एक वर्ग का नाम शुरू करें।
model.Model का मतलब है कि पोस्ट एक Django मॉडल है, इसलिए Django जानता है कि इसे डेटाबेस में सहेजा जाना चाहिए।
अब हम उन गुणों के बारे में चर्चा करते हैं जिन्हें हम ऊपर परिभाषित करते हैं: शीर्षक, पाठ, create_date, publish_date और लेखक। ऐसा करने के लिए, हमें प्रत्येक क्षेत्र के प्रकार को परिभाषित करने की आवश्यकता है।
model.CharField - यह है कि आप पाठ को सीमित संख्या में वर्णों के साथ कैसे परिभाषित करते हैं।
Model.TextField - यह एक सीमा के बिना लंबे पाठ के लिए है।
Model.DateTimeField - यह दिनांक और समय के लिए है।
Model.ForeignKey - यह दूसरे मॉडल का लिंक है।
हम एक फ़ंक्शन / विधि को परिभाषित करते हैं def और प्रकाशित विधि का नाम है।
विधियाँ अक्सर कुछ लौटा देती हैं। जब हम __str __ () कहते हैं, तो हमें पोस्ट शीर्षक के साथ एक पाठ (स्ट्रिंग) मिलेगा।
अपने डेटाबेस में मॉडल के लिए टेबल बनाना
अंतिम चरण हमारे डेटाबेस में एक नया मॉडल जोड़ना है। सबसे पहले, हमें Django को यह समझने देना होगा कि हमने अपने मॉडल में कुछ बदलाव किए हैं। आइए हम अपने कंसोल विंडो में कमांड के साथ ऐसा ही करते हैंpython manage.py make migrations myBlog जैसा कि नीचे दिखाया गया है -
फिर, Django एक माइग्रेशन फ़ाइल तैयार करता है जिसे अब हमें अपने डेटाबेस पर लागू करना है। हमारे कंसोल में हम टाइप कर सकते हैं:python manage.py migrate myBlog और आउटपुट इस प्रकार होना चाहिए -
हमारा पोस्ट मॉडल अब हमारे डेटाबेस में है।
Django व्यवस्थापक
हमारे द्वारा अभी पोस्ट किए गए पोस्ट को जोड़ने, संपादित करने और हटाने के लिए, हम Django व्यवस्थापक का उपयोग कर रहे हैं।
तो आइए हम खोलते हैं myBlog/admin.py file और इसमें नीचे सामग्री डालें -
सबसे पहले, हम पिछले अध्याय में परिभाषित पोस्ट मॉडल को आयात (शामिल) करते हैं। हमारे मॉडल को व्यवस्थापक पृष्ठ पर दिखाई देने के लिए, हमें admin.site.register (पोस्ट) के साथ मॉडल को पंजीकृत करना होगा।
एक व्यवस्थापक साइट में प्रवेश करने के लिए, आपको एक सुपरयुसर बनाने की आवश्यकता है - एक उपयोगकर्ता खाता जो साइट पर सब कुछ पर नियंत्रण रखता है। तो वेबसर्वर बंद करो और कमांड लाइन अजगर में टाइप करेंmanage.py createsuperuser, और एंटर दबाएं।
ठीक है, तो यह हमारे पोस्ट मॉडल को देखने का समय है। वेब सर्वर को चलाने के लिए कंसोल में अजगर प्रबंधन ओरेकल चलाने के लिए याद रखें। अपने ब्राउज़र पर जाएं और पता लिखेंhttps://127.0.0.1:8000/admin/.उन क्रेडेंशियल्स के साथ लॉग इन करें जिन्हें हमने अभी चुना है। फिर आपको नीचे के रूप में Django व्यवस्थापक डैशबोर्ड देखना चाहिए -
पोस्ट पर जाएं और इसके साथ थोड़ा प्रयोग करें। आप कहीं से भी कई ब्लॉग पोस्ट और सामग्री जोड़ सकते हैं। आपका ब्लॉग कुछ इस तरह दिखेगा -
यह केवल Django का अवलोकन है और हम कोड की कुछ पंक्तियों के साथ एक ब्लॉग बनाने में सक्षम हैं।
फ्लास्क माइक्रो-फ्रेमवर्क है जिसकी बाहरी पुस्तकालयों पर बहुत कम निर्भरता है। यह एक बहुत ही हल्का ढांचा है और हमें जो कुछ भी चाहिए उसे करने की स्वतंत्रता देता है।
इस अध्याय में, हम पायथन और फ्लास्क ढांचे का उपयोग करके एक परियोजना का निर्माण करने जा रहे हैं।
फ्लास्क स्टार्टअप और कॉन्फ़िगरेशन
सबसे अधिक व्यापक रूप से उपयोग किए जाने वाले अजगर पुस्तकालयों की तरह, फ्लास्क पैकेज पायथन पैकेज इंडेक्स (पीपीआई) से स्थापित करने योग्य है। पहले एक निर्देशिका बनाते हैं (इस अध्याय में, हमने एक निर्देशिका बनाई है जिसे कहा जाता हैflaskProject) फिर एक आभासी वातावरण बनाया (और इसे कहा जाता है flaskEnv) जहां परियोजना संबंधी सभी निर्भरताएँ लोड की जाएंगी (फ्लास्क सहित)। आप फ्लास्क- sqlalchemy भी स्थापित कर सकते हैं ताकि आपके फ्लास्क एप्लिकेशन में SQL डेटाबेस के साथ संवाद करने का एक सरल तरीका हो।
फ्लास्क को स्थापित करने के बाद, आपका फ्लास्कएन्विव (हमारा वर्चुअलीवर्जन नाम) कुछ इस प्रकार दिखाएगा -
फ्लास्क के साथ एक ऐप बनाना
फ्लास्क स्थापित करके, हम एक सरल बना सकते हैं ”hello application in flask"कोड की बहुत कम पंक्तियों के साथ इस प्रकार है -
टर्मिनल में निम्नलिखित टाइप करें -
$python flaskapp.py
और आप निम्न आउटपुट देख सकते हैं -
पर चल रहा है http://127.0.0.1:5000/ या पर localhost:5000
नीचे हमने अपने उदाहरण कोड में क्या किया, इसकी व्याख्या है -
सबसे पहले, हम फ्लास्क क्लास लाइब्रेरी आयात करते हैं। इस वर्ग का एक उदाहरण WSGI ऐप है।
दूसरे, हम इस वर्ग का एक उदाहरण बनाते हैं। एप्लिकेशन पैकेज या मॉड्यूल नाम हमारा पहला तर्क है। यह अनिवार्य है कि फ्लास्क जानता है कि स्थिर फाइलें, टेम्प्लेट और अन्य फाइलें कहां मिलेंगी।
अगला मार्ग है () डेकोरेटर जिसका उपयोग हम यह जानने के लिए करते हैं कि किस URL को हमारी विधि / फ़ंक्शन को ट्रिगर करना चाहिए।
URL रूटिंग बनाना
URL रूटिंग आपके वेब ऐप में URL को याद रखने में आसान बनाता है। अब हम कुछ URL रूट बनाएंगे -
/hello
/members
/members/name
हम उपरोक्त URL के आधार पर निम्नलिखित कोड लिख सकते हैं और इसे app.py के रूप में सहेज सकते हैं।
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/')
def index():
return "Index!"
@app.route('/Hello')
def hello():
return "Hello, World!"
@app.route("/members")
def members():
return "Members"
@app.route("/members/<name>/")
def getMember(name):
return name
if __name__ == '__main__':
app.run(debug=True)
$ python app.py
Running on http://localhost:5000/
हम अपने ब्राउज़र में निम्न आउटपुट प्राप्त करेंगे -
हम अपने ब्राउज़र में अन्य URL को इस प्रकार आज़मा सकते हैं -
Running on http://localhost:5000/hello, will give the following output −
Running on http://localhost:5000/members, will give −
Running on http://localhost:5000/members/TutorialsPoint/, will give you the following output −
लेकिन आम तौर पर हम एक स्ट्रिंग (जैसा कि ऊपर) वापस नहीं करना चाहते हैं, हम टेम्पलेट्स लौटाते हैं। इसके लिए हम एक फ़ंक्शन का उपयोग करना चाहते हैं ”render_templateफ्लास्क से, और कुछ इनपुट के साथ render_template लौटाएं। तो, नीचे कार्य हमारे काम करेगा -
from flask import render_template
return render_template(‘home.html’)
आइए हम एक फ़ोल्डर टेम्पलेट बनाते हैं और उसमें home.html फ़ाइल डालते हैं।
अगला, हम लेआउट के बारे में चर्चा करेंगे। हर एक टेम्पलेट के लिए html हेड टैग और बॉडी टैग का उपयोग करने के बजाय, हम हेड एंड बॉडी टैग को शामिल करने के लिए एक लेआउट डिज़ाइन करेंगे और वर्तमान दृश्यों या वर्तमान टेम्पलेट को लपेटेंगे। उसके लिए हमें एक अलग फाइल बनानी होगी और उसे कॉल करना होगाlayout.html। इसमें हम अपना सामान्य हेड टैग, बॉडी टैग और अन्य सभी आवश्यक टैग लगा सकते हैं।
हम कोड की निम्नलिखित पंक्तियों के साथ अपना नया लेआउट.html बना सकते हैं -
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>MyFlaskApp</title>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css">
</head>
<body>
{% include 'includes/_navbar.html' %}
<div class="container">
{% block body %}
{% endblock %}
</div>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js">
</script>
</body>
</html>
उपरोक्त कोड में, हमने टाइटल ट्रैक, MyFlaskAp, सिर में css cdn और बूट ब्लॉक को सक्षम करने के लिए बॉडी ब्लॉक में जावास्क्रिप्ट का उपयोग किया है।
अब, हमें हर एक पेज के लिए नेवबार बनाना है। उसके लिए, हमें पहले एक सम्मिलित फ़ोल्डर बनाना होगा और फिर उसके अंदर _navbar.html फ़ाइल बनाना होगा। अब _navbar.html में, हमें getbootstrap.com से मानक स्टार्टर टेम्पलेट का उपयोग करना होगा। नव निर्मित _navbar.html फ़ाइल निम्नानुसार होगी -
और इस _navbar.html फ़ाइल को हमारे layout.html फ़ाइल में शामिल करें।
{% include 'includes/_navbar.html' %}
जैसा कि हमारे पास लेआउट ब्लॉक है, हम इस ब्लॉक को अपनी होम फाइल (home.html) में बढ़ा सकते हैं।
नीचे दिए गए कोड का उपयोग करके हमारी home.html फ़ाइल बनाई जा सकती है -
{% extends 'layout.html' %}
{% block body %}
<div class="jumbotron text-center">
<h1>Welcome to FlaskApp</h1>
<p>This application is built on Flask webframework!</p>
</div>
{% endblock %}
इसका उपयोग करते हुए यदि हम अपनी फ्लास्कैपहोम फ़ाइल चलाने की कोशिश करते हैं, तो हम अपने ब्राउज़र में निम्न आउटपुट देख सकते हैं -
अब हम सक्रिय करना चाहते हैं (वर्तमान में टैब काम नहीं कर रहे हैं) हमारे aboutटैब। लगभग टैब के लिए एक मार्ग बनाएँ और एक टेम्पलेट फ़ाइल बनाएँ,about.html।
Appflask.py में टैब रूट के बारे में नीचे दिखाया गया है -
about.html फ़ाइल में नीचे दी गई सामग्री होगी -
इसलिए होम और अब के बारे में ध्यान रखा जाता है। लेखों के लिए, हम रूट डायरेक्टरी में एक नई फ़ाइल (data.py) बना सकते हैं, जहाँ हम डेटा डालते हैं और इसे अपने वेबपेज में कॉल करते हैं।
data.py
def Articles():
articles = [
{
'uid': 1,
'title': 'Article_One',
'body': 'Flask, being a microframework, often requires some repetitive step
to get a third party library working. Because very often these steps could
be abstracted to support multiple projects the Flask Extension Registry
was created.',
'Author': 'Rajesh Joshi',
'Created-on': '07-09-2018'
},
{
'uid': 2,
'title': 'Article_Two',
'body': "Flask, being a microframework, often requires some repetitive steps
to get a third party library working. Because very often these steps could
be abstracted to support multiple projects the Flask Extension Registry
was created.",
'Author': 'Rajesh J',
'Created-on': '07-09-2018'
},
{
'uid': 3,
'title': 'Article_Three',
'body': 'Flask, being a microframework, often requires some repetitive steps
to get a third party library working. Because very often these steps could be
abstracted to support multiple projects the Flask Extension Registry
was created.',
'Author': 'Joshi Rajesh',
'Created-on': '07-09-2018'
}
]
return articles
नीचे के लिए कोड है articles.html, जो प्रत्येक यूआईडी के लिए लेख शीर्षक प्रदर्शित करेगा।
{% extends 'layout.html' %}
{% block body %}
<h1>Articles</h1>
{% for article in articles %}
<li class="list-group-item">
<a href="article/{{article.uid}}"> {{article.title}}</a>
</li>
{% endfor %}
{% endblock %}
संक्षेप में, फ्लास्क अपने हल्के होने के कारण सबसे लोकप्रिय अजगर वेब फ्रेमवर्क में से एक है। हालांकि यह माइक्रो है यह एक एक्स्टेंसिबल पायथन वेब फ्रेमवर्क है। आवश्यक कार्यक्षमता प्रदान करके, फ्लास्क सरल वेब अनुप्रयोग के विकास को तेज करता है। तो फ्लास्क, छोटे, कम जटिल अनुप्रयोगों के लिए अधिक उपयुक्त है।
Web2py एक आसानी से उपयोग होने वाली रूपरेखा है। Web2py के साथ, किसी भी इंस्टॉलेशन और कॉन्फ़िगरेशन की आवश्यकता नहीं है क्योंकि यह पोर्टेबल है और इसे यूएसडी ड्राइव पर भी चलाया जा सकता है। यह कई अन्य अजगर फ्रेमवर्क की तरह एमवीसी फ्रेमवर्क पर आधारित है। हालांकि उनमें से अधिकांश पायथन के पुराने संस्करणों का समर्थन नहीं करते हैं, फिर भी वेब 2 पी पुराने संस्करणों का समर्थन करता है: अजगर 2.6 और 2.7। यह प्रमाणीकरण के लिए LDAP का भी समर्थन करता है जो इन दिनों व्यापक रूप से स्वीकृत है।
Web2py तीन मुख्य लक्ष्यों पर ध्यान केंद्रित करके वेब विकास में प्रवेश की बाधा को कम करने की कोशिश करता है -
- त्वरित विकास
- उपयोग में आसानी
- Security
उपयोगकर्ता के दृष्टिकोण को ध्यान में रखते हुए, Web2py बनाया गया है और इसे आंतरिक रूप से अनुकूलित किया जा रहा है ताकि इसे आगे की अनुकूलता के लिए समर्थन सहित एक तेज और दुबला ढांचा बनाया जा सके।
Web2py फ्रेमवर्क को स्थापित और कॉन्फ़िगर करना
Web2py चलाना आसान है, आपको नीचे दिए गए लिंक से exe डाउनलोड करना होगा: http://www.web2py.com/init/default/download
खिड़कियों के लिए, आप ज़िप फ़ाइल डाउनलोड कर सकते हैं, इसे अनज़िप कर सकते हैं और एक्साई फ़ाइल को सीधे या कमांड लाइन से चला सकते हैं। आपको नीचे स्क्रीन के साथ व्यवस्थापक पासवर्ड के लिए कहा जाएगा।
आप एक व्यवस्थापक पासवर्ड चुन सकते हैं और सर्वर शुरू कर सकते हैं। आप निम्न स्क्रीन देखेंगे -
Web2py का उपयोग करके एक ऐप बनाना
अब हम एक नया ऐप बनाने के लिए तैयार हैं। सबसे नीचे स्थित एडमिन टैब पर क्लिक करें। तो व्यवस्थापक पासवर्ड दर्ज करने के बाद, हम नीचे स्क्रीन प्राप्त करेंगे -
नए सरल एप्लिकेशन पर जाएं, कुछ एप्लिकेशन नाम दर्ज करें (जैसे helloWeb2py) और क्रिएट पर क्लिक करें। यह नीचे दिए गए अनुसार डिज़ाइन इंटरफ़ेस पेज प्रदर्शित करेगा -
आप अपने वर्तमान लाइव वेब पर जा सकते हैं, helloWeb2py, बस टाइप करें http://127.0.0.1:8000/helloWeb2py अपने स्थानीय मशीन पर, आप नीचे उत्पादन मिल जाएगा -
HelloWeb2py एप्लिकेशन के डिज़ाइन पृष्ठ में, कंट्रोलर पर जाएं और default.py के बगल में एडिट बटन पर क्लिक करें। यदि आप अनुक्रमणिका () फ़ंक्शन का रिटर्न मान बदलते हैं, तो निम्न आउटपुट प्रदर्शित किया जाएगा -
परिवर्तनों को सहेजें, और अब आप अपने helloWeb2py ऐप में किए गए परिवर्तनों की जाँच कर सकते हैं। बस ताज़ा करेंhttp://127.0.0.1:8000/helloWeb2py लिंक और आप नीचे उत्पादन देखेंगे -
क्लाउड प्लेटफॉर्म पर ऐप की तैनाती
अब यदि आप अपने ऐप को क्लाउड प्लेटफ़ॉर्म पर तैनात करना चाहते हैं, तो अपने होम पेज पर वापस आएं और साइट पर क्लिक करें। आप तैनाती के लिए कोई भी विकल्प चुन सकते हैं। यहाँ, हम "pythonAnywhere" चुनते हैं। PythonAnywhere वेबसाइट पर जाएं और अपना पंजीकरण करें (यदि पहले से नहीं हुआ है)। पर क्लिक करें“Add a new web app”और सभी क्रेडेंशियल भरें (web2py ऐप चुनें)। सब कुछ कर दिया।
अब जाना है https://username.pythonanywhere.com/welcome/default/index, व्यवस्थापक टैब पर क्लिक करें (पासवर्ड दर्ज करें)। आगे अपलोड पर क्लिक करें और पैक्ड एप्लिकेशन इंस्टॉल करें। नीचे के रूप में क्रेडेंशियल्स भरें और इंस्टॉल पर क्लिक करें।
एक बार सब कुछ हो जाने के बाद, एक पॉप-अप संदेश नीचे दिए गए अनुसार दिखाई देगा -
अब अपना ऐप देखने के लिए, नीचे दिए गए लिंक को खोलें -
https://username.pythonanywhere.com/welcome/default/index और आप निम्न स्क्रीन देख सकते हैं -
हमारा पहला web2py एप्लिकेशन सफलतापूर्वक बनाया और तैनात किया गया है।
संक्षेप में, Web2py एक स्वतंत्र, तेज, सुरक्षित वेब विकास ढांचा है जो पूरी तरह से अजगर में लिखा गया है और हर तरह से संभव (मॉडल, दृश्य, नियंत्रक) में अजगर का उपयोग करने के लिए प्रोत्साहित करता है। यह छोटे वेब अनुप्रयोगों या प्रोटोटाइप के लिए एक बहुत अच्छा ढांचा है लेकिन उद्यम वर्ग की गुणवत्ता की आवश्यकताओं को पूरा करने में विफल रहता है। ऐसा इसलिए है, क्योंकि उद्यम स्तर के आवेदन में, बग्स को हल करने की जटिलता इकाई परीक्षणों की कमी, अच्छी और सटीक त्रुटि रिपोर्टिंग और बिखरे मॉडल की वजह से तेजी से बढ़ जाएगी।
पिरामिड एक सामान्य, खुला स्रोत, अजगर में निर्मित वेब अनुप्रयोग विकास ढांचा है। यह अजगर डेवलपर को आसानी से वेब एप्लिकेशन बनाने की अनुमति देता है।
स्थापित करना, शुरू करना और कॉन्फ़िगर करना
जैसा कि वर्णन किया गया है, "छोटी शुरुआत, बड़ी खत्म, समाप्त हो गई रूपरेखा", पिरामिड बहुत कुछ फ्लास्क की तरह है जो स्थापित करने और चलाने के लिए बहुत कम प्रयास करता है। वास्तव में, आप पहचान लेंगे कि इस एप्लिकेशन का निर्माण शुरू करते ही कुछ पैटर्न फ्लास्क के समान हैं।
पिरामिड फ्रेमवर्क वातावरण बनाने के लिए निम्नलिखित कदम हैं: -
सबसे पहले, एक परियोजना निर्देशिका बनाएं। यहां, हमने एक निर्देशिका बनाई है जिसका नाम हैpyramidProject (आप चाहें तो कोई भी नाम चुन सकते हैं)।
अगला, एक आभासी वातावरण बनाएं जहां आप सभी परियोजना विशिष्ट निर्भरताएं स्थापित करेंगे। यहां, हमने एक वर्चुअल एनवायरनमेंट फोल्डर बनाया है जिसका नाम हैpyramidEnv जहां पिरामिड स्थापित है।
फिर, डायरेक्टरी पर जाएं, pyramidEnv और के साथ पिरामिड स्थापित करें pip install pyramid।
एक बार जब सब कुछ ऊपर वर्णित है, तो आपकी निर्देशिका संरचना नीचे दी गई है -
और सिस्टम में स्थापित पिरामिड संस्करण नीचे दिया गया है -
मूल अवधारणा
पिरामिड फ्रेमवर्क मुख्य अवधारणाओं के नीचे आधारित है -
Zope (एक्स्टेंसिबिलिटी, ट्रैवर्सल, डिक्लेरेटिव सिक्योरिटी) - एक्सट्रेंसिटी, ट्रैवर्सल के कॉन्सेप्ट और डिक्लेक्टिव सिक्योरिटी के लिहाज से पिरामिड लूप पर आधारित है।
Pylons(URL प्रेषण, हठ, टेंपलेटिंग, आदि के बारे में बिना किसी विचार के) - एक अन्य क्षेत्र जहां से पिरामिड अपनी अवधारणा को खींचता है, वह है पाइलोंस प्रोजेक्ट। पाइलों में मार्गों की वह अवधारणा है, जो पिरामिड ढांचे के अंदर URL प्रेषण को कॉल करती है और उनके पास दृढ़ता परत या टेम्प्लेटिंग के बारे में गैर-राय है।
Django(देखें, प्रलेखन का स्तर) - पिरामिड भी Django से संकेत मिलता है। जिस तरह से हम अपना दृष्टिकोण लेते हैं, हमारे URL को रूट किया जाता है और प्रलेखन का स्तर बहुत Django तरीका है।
पिरामिड ढांचे की विशेषताएं निम्नलिखित हैं -
यह सबसे तेजी से ज्ञात पायथन वेब फ्रेमवर्क है।
यह छोटी और बड़ी परियोजनाओं का समर्थन करता है (जब आप अपने छोटे ढांचे को आगे बढ़ाते हैं तो फिर से लिखना क्यों)।
यह माइक्रोफ्रामवर्क की तरह सिंगल फाइल वेबैप्स को सपोर्ट करता है।
इसमें बिल्ट-इन सेशन हैं।
यह Plone / Zope जैसी घटनाओं का समर्थन करता है।
यह लेन-देन प्रबंधन प्रदान करता है (यदि पहले से ही ध्यान दिया है कि हमने ज़ोप से पहले उपयोग किया है)।
विन्यास
कॉन्फ़िगरेशन वह सेटिंग्स है जो किसी एप्लिकेशन के संचालन को प्रभावित करती है। पिरामिड एप्लिकेशन को कॉन्फ़िगर करने के दो तरीके हैं: अनिवार्य कॉन्फ़िगरेशन और घोषणात्मक कॉन्फ़िगरेशन।
पिरामिड विन्यास का समर्थन करता है -
इम्पीरियल कॉन्फ़िगरेशन या यहां तक कि डेकोरेटर-आधारित कॉन्फ़िगरेशन का ओवरराइडिंग
कॉन्फ़िगरेशन संघर्ष का पता लगाने (अधिक स्थानीय बनाम कम स्थानीय निर्धारण सहित)
कॉन्फ़िगरेशन एक्स्टेंसिबिलिटी (कई ऐप्स से शामिल)
लचीले प्रमाणीकरण और प्राधिकरण नीतियां
विन्यास का प्रोग्रामेटिक इंट्रोस्पैक्शन (नव-निर्माण के लिए मार्गों की वर्तमान स्थिति देखें)
URL पीढ़ी
पिरामिड में, हम मार्गों, संसाधनों और स्थिर संपत्तियों के लिए URL जनरेट कर सकते हैं। URL जनरेशन API के साथ काम करना आसान और लचीला है। पिरामिड के विभिन्न एपीआई के माध्यम से यूआरएल उत्पन्न करके, उपयोगकर्ता आपके किसी भी वेब पेज के साथ लिंक को तोड़ने की बहुत चिंता किए बिना मनमाने ढंग से कॉन्फ़िगरेशन को बदल सकते हैं।
तो संक्षेप में, पिरामिड में URL -
लिंक नहीं तोड़ने वाले ऐप में परिवर्तन की अनुमति देने के लिए URL पीढ़ी का समर्थन करता है।
स्थैतिक संसाधनों के लिए URL उत्पन्न करता है जो अनुप्रयोग के अंदर या बाहर रहते हैं।
रूट और ट्रैवर्सल का समर्थन करता है।
विचारों
पिरामिड की प्राथमिक नौकरियों में से एक यह है कि जब कोई अनुरोध आपके आवेदन पर पहुंचता है, तो उसे कॉल करने योग्य देखने और प्राप्त करने के लिए। दृश्य कॉलिबल कोड के बिट्स हैं जो आपके आवेदन में किए गए अनुरोध के जवाब में कुछ दिलचस्प करते हैं।
जब आप अपने विचारों को अपने URL प्रेषण या अजगर कोड पर मैप करते हैं, तो किसी भी प्रकार की कॉल हो सकती है। दृश्य एक फ़ंक्शन घोषणा या एक उदाहरण हो सकता है, इसका उपयोग पिरामिड में एक दृश्य के रूप में किया जा सकता है।
दृश्य के बारे में कुछ महत्वपूर्ण बिंदु नीचे दिए गए हैं -
किसी भी कॉल करने योग्य से दृश्य उत्पन्न होते हैं।
रेंडरर आधारित विचार केवल शब्दकोशों को वापस कर सकते हैं (वेब स्टाइल शैली ऑब्जेक्ट को वापस करने के लिए आवश्यक नहीं है)।
प्रति रूट (एकाधिक बनाम पोस्ट बनाम HTTP हेडर चेक, आदि) का समर्थन करें।
प्रतिक्रिया एडेप्टर देखें (जब आप यह निर्दिष्ट करना चाहते हैं कि रिटर्न वैल्यूज को कैसे देखा जाना चाहिए बनाम प्रतिक्रिया ऑब्जेक्ट्स)।
तानाना
पिरामिड को मन में उतार-चढ़ाव के साथ डिजाइन किया गया है। इसलिए यदि कोई पिरामिड डेवलपर किसी एप्लिकेशन का निर्माण करते समय कुछ बाधाओं को ध्यान में रख रहा है, तो तीसरे पक्ष को अपने स्रोत कोड को संशोधित करने की आवश्यकता के बिना एप्लिकेशन के व्यवहार को बदलने में सक्षम होना चाहिए। एक पिरामिड अनुप्रयोग का व्यवहार जो कुछ बाधाओं का पालन करता है, को बिना किसी संशोधन के ओवरराइड या विस्तारित किया जा सकता है। यह कई वातावरणों (नो सिंग्लटन) के लिए लचीली तैनाती के लिए बनाया गया है। पिरामिड में "ट्ववेन्स" मिडलवेयर सपोर्ट (WSGI बीच वेयर है, लेकिन पिरामिड के संदर्भ में ही चलता है)।
हैलो, पिरामिड प्रोग्राम चलाना
सब कुछ ठीक काम कर रहा है या नहीं यह जांचने के लिए पिरामिड फ्रेमवर्क को स्थापित करने के बाद हम जो सबसे सरल प्रोग्राम सोच सकते हैं, वह है एक सरल "हैलो, वर्ल्ड" या "हैलो, पिरामिड" प्रोग्राम।
नीचे 8000 पोर्ट नंबर पर मेरा पिरामिड "हैलो, पिरामिड" प्रोग्राम है -
सरल उदाहरण से ऊपर चलाना आसान है। इसे app.py के रूप में सहेजें (इसमें हमने pyramid_helloW.py नाम दिया है)।
सबसे सरल कार्यक्रम चलाना: -
अगला, खुला http://localhost:8000/एक ब्राउज़र में, और आप हैलो, पिरामिड देखेंगे! संदेश इस प्रकार है -
उपरोक्त कोड के लिए स्पष्टीकरण निम्नलिखित है -
लाइन नं। 1-3
फ़ाइल के शीर्ष पर, हमारे पास आयात कथन हैं। पहली पंक्ति मेक_सर्वर फ़ंक्शन को आयात करती है, जो किसी एप्लिकेशन के पास जाने पर एक साधारण वेब सर्वर बना सकती है। दूसरी और तीसरी पंक्ति पिरामिड से कॉन्फ़िगरेशन और रिस्पॉन्स फ़ंक्शन को आयात करती है। इन कार्यों का उपयोग विवरण को कॉन्फ़िगर करने और क्रमशः आवेदन के लिए पैरामीटर सेट करने और अनुरोधों का जवाब देने के लिए किया जाता है।
लाइन नं। 5-6
अब हमारे पास एक फंक्शन डेफिनिशन है जिसे कहा जाता है hello_world। प्रतिक्रिया को उत्पन्न करने वाला दृश्य कोड लागू करें। एक फ़ंक्शन जो किसी दृश्य की आवश्यकता को पूरा करता है, पाठ को प्रस्तुत करने के लिए ज़िम्मेदार होता है जिसे अनुरोध इकाई में वापस पारित किया जाएगा। उपरोक्त मामले में, फ़ंक्शन, जिसे कॉल किया जाता है, रिस्पॉन्स फ़ंक्शन का उपयोग करता है जिसे हमने पहले आयात किया था। यह एक मान वापस करता है जो क्लाइंट को दिया जाना चाहिए।
लाइन नं। 8
अगर __name__ == '__main__': पायथन कह रहा है, "कमांड लाइन से चलने पर यहां शुरू करें", बजाय इसके कि यह मॉड्यूल आयात किया गया है।
लाइन नं। 9-11
लाइन नं। 9, हम प्रोग्रामर फ़ंक्शन द्वारा बनाई गई ऑब्जेक्ट से बाहर एक वैरिएबल बनाते हैं जिसे हमने प्रोग्राम के शीर्ष पर आयात किया था। लाइन 10 और 11 इस ऑब्जेक्ट के add_route और add_view पद्धति को कॉल करते हैं। इस पद्धति का उपयोग उस दृश्य को परिभाषित करने के लिए किया जाता है जिसका उपयोग एप्लिकेशन द्वारा किया जा सकता है। जैसा कि हम देख सकते हैं, हम पहले से परिभाषित हेलो_वर्ल्ड फ़ंक्शन को पास करते हैं। यह वह जगह है जहां वास्तव में एक दृश्य के रूप में उस फ़ंक्शन को शामिल किया गया है।
लाइन नं। 12-14
इसमें, हम वास्तव में config ऑब्जेक्ट के make_wsgi_app विधि को कॉल करके WSGI एप्लिकेशन बनाते हैं। यह ऑब्जेक्ट की विशेषताओं का उपयोग करता है, जैसे कि हमने जो दृश्य जोड़ा, वह एप्लिकेशन बनाने के लिए। यह एप्लिकेशन तब मेक_सर्वर फ़ंक्शन में जाता है, जिसे हमने एक ऑब्जेक्ट बनाने के लिए आयात किया है जो हमारे एप्लिकेशन को सेवा देने के लिए एक वेब सर्वर लॉन्च कर सकता है। अंतिम पंक्ति इस सर्वर को लॉन्च करती है।
हमारी hello world applicationसबसे सरल और आसान संभव पिरामिड अनुप्रयोगों में से एक है, जिसे "अनिवार्य रूप से" कॉन्फ़िगर किया गया है। यह जरूरी है क्योंकि पाइथन की पूरी शक्ति हमारे पास उपलब्ध है क्योंकि हम विन्यास कार्य करते हैं।
संक्षेप में, पिरामिड एक बड़ा और सक्रिय समुदाय के साथ एक खुला स्रोत अजगर वेब फ्रेमवर्क है। यह बड़ा समुदाय अजगर वेब ढांचे को लोकप्रिय और प्रासंगिक बनाने में योगदान देता है। पिरामिड वेब ढांचे को मजबूत सुविधाओं और उपकरणों का एक सेट प्रदान करके वेब अनुप्रयोग विकास को सरल और तेज करता है।
इस अध्याय में, हम डैश फ्रेमवर्क के बारे में विस्तार से चर्चा करेंगे।
डैश एक ओपन-सोर्स पायथन फ्रेमवर्क है जिसका उपयोग विश्लेषणात्मक वेब अनुप्रयोगों के निर्माण के लिए किया जाता है। यह एक शक्तिशाली पुस्तकालय है जो डेटा-संचालित अनुप्रयोगों के विकास को सरल करता है। यह पायथन डेटा वैज्ञानिकों के लिए विशेष रूप से उपयोगी है जो वेब विकास से बहुत परिचित नहीं हैं। उपयोगकर्ता डैश का उपयोग करके अपने ब्राउज़र में अद्भुत डैशबोर्ड बना सकते हैं।
Plotly.js, React, और Flask के शीर्ष पर निर्मित, डैश आपके UI के ड्रापडाउन, स्लाइडर्स और ग्राफ़ जैसे आधुनिक UI तत्वों को सीधे आपके विश्लेषणात्मक अजगर कोड से जोड़ता है।
डैश ऐप्स में एक फ्लास्क सर्वर होता है जो HTTP अनुरोधों पर JSON पैकेट्स का उपयोग करके फ्रंट-एंड रिएक्ट घटकों के साथ संचार करता है।
डैश एप्लिकेशन को शुद्ध रूप से अजगर में लिखा गया है, इसलिए NO HTML या जावास्क्रिप्ट आवश्यक है।
डैश सेटअप
यदि डैश आपके टर्मिनल में पहले से स्थापित नहीं है, तो नीचे बताए गए डैश लाइब्रेरी को स्थापित करें। जैसा कि ये पुस्तकालय सक्रिय विकास के तहत हैं, स्थापित करें और अपग्रेड करें। अजगर 2 और 3 भी समर्थित हैं।
- पाइप इंस्टॉल डैश == 0.23.1 # कोर डैश बैकएंड
- पाइप इंस्टॉल डैश-रेंडरर == 0.13.0 # डैश फ्रंट-एंड
- पाइप स्थापित डैश-एचटीएमएल-घटकों == 0.11.0 # HTML घटकों
- पाइप स्थापित डैश-कोर-घटक == 0.26.0 # सुपरचार्ज किए गए घटक
- पाइप स्थापित प्लॉटली == 3.1.0 # प्लॉटली लायब्रेरी
यह सुनिश्चित करने के लिए कि सब कुछ ठीक से काम कर रहा है, यहाँ, हमने एक साधारण डैशऐफ़डी फ़ाइल बनाई।
डैश या ऐप लेआउट
डैश ऐप दो भागों से बना होता है। पहला भाग ऐप का "लेआउट" है जो मूल रूप से बताता है कि आवेदन कैसा दिखता है। दूसरा भाग अनुप्रयोग की अन्तरक्रियाशीलता का वर्णन करता है।
प्रमुख घटक
हम के साथ लेआउट का निर्माण कर सकते हैं dash_html_components और यह dash_core_componentsपुस्तकालय। डैश अनुप्रयोग के सभी दृश्य घटकों के लिए अजगर कक्षाएं प्रदान करता है। हम जावास्क्रिप्ट और React.js के साथ अपने स्वयं के घटकों को भी अनुकूलित कर सकते हैं।
dcc के रूप में आयात dash_core_compenders
HTML के रूप में आयात डैश_एचटीएमएल_कंप्यूटर
डैश_एचटीएमएल_सेंटर उन सभी एचटीएमएल टैगों के लिए है जहां डैश_कोर_सेंटर रिएक्ट.जेएस के साथ निर्मित अन्तरक्रियाशीलता के लिए है।
उपरोक्त दो पुस्तकालयों का उपयोग करते हुए, हम नीचे दिए गए अनुसार एक कोड लिखें -
app = dash.Dash()
app.layout = html.Div(children=[
html.H1(children='Hello Dash'),
html.Div(children='''Dash Framework: A web application framework for Python.''')
और समतुल्य HTML कोड इस तरह दिखेगा -
<div>
<h1> Hello Dash </h1>
<div> Dash Framework: A web application framework for Python. </div>
</div>
सरल डैश एप्लिकेशन लेखन
हम सीखेंगे कि किसी फ़ाइल में उपर्युक्त लाइब्रेरी का उपयोग करके डैश पर एक सरल उदाहरण कैसे लिखें dashApp.py।
# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html
app = dash.Dash()
app.layout = html.Div(children=[
html.H1(children='Hello Dash'),
html.Div(children='''Dash Framework: A web application framework for Python.'''),
dcc.Graph(
id='example-graph',
figure={
'data': [
{'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'Delhi'},
{'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Mumbai'},
],
'layout': {
'title': 'Dash Data Visualization'
}
}
)
])
if __name__ == '__main__':
app.run_server(debug=True)
डैश ऐप चला रहा है
डैश ऐप चलाते समय निम्नलिखित बातों पर ध्यान दें।
(MyDjangoEnv) C: \ Users \ rajesh \ Desktop \ MyDjango \ डैश> python dashApp1.py
फ्लास्क ऐप "डैशऐप 1" सेवा (आलसी लोडिंग)
पर्यावरण: उत्पादन
चेतावनी: उत्पादन वातावरण में विकास सर्वर का उपयोग न करें।
इसके बजाय उत्पादन WSGI सर्वर का उपयोग करें।
डिबग मोड: पर
स्टैट के साथ फिर से शुरू करना
डीबगर सक्रिय है!
डीबगर पिन: 130-303-947
पर चल रहा है http://127.0.0.1:8050/ (छोड़ने के लिए CTRL + C दबाएं)
127.0.0.1 - - [12/Aug/2018 09:32:39] "GET / HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /_dash-layout HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /_dash-dependencies HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /favicon.ico HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:39:52] "GET /favicon.ico HTTP/1.1" 200 -
यात्रा http:127.0.0.1:8050/अपने वेब ब्राउज़र में। आपको एक ऐप देखना चाहिए जो इस तरह दिखता है।
उपरोक्त कार्यक्रम में, नोट किए जाने वाले कुछ महत्वपूर्ण बिंदु इस प्रकार हैं -
एप्लिकेशन लेआउट HTML.Div और dcc.Graph जैसे "घटकों" के एक पेड़ से बना है।
प्रत्येक HTML टैग के लिए डैश_एचटीएमएल_कंप्यूटर लाइब्रेरी का एक घटक है। HTML.H1 (बच्चों = 'हैलो डैश') घटक आपके आवेदन में एक <h1> हैलो डैश </ h1> HTML तत्व उत्पन्न करता है।
सभी घटक शुद्ध HTML नहीं हैं। डैश_कोर_कंप्यूटर उच्च-स्तरीय घटकों का वर्णन करते हैं जो इंटरएक्टिव होते हैं और रिएक्ट.एक्स लाइब्रेरी के माध्यम से जावास्क्रिप्ट, एचटीएमएल और सीएसएस के साथ उत्पन्न होते हैं।
प्रत्येक घटक को पूरी तरह से कीवर्ड विशेषताओं के माध्यम से वर्णित किया गया है। डैश घोषणात्मक है: आप मुख्य रूप से इन विशेषताओं के माध्यम से अपने आवेदन का वर्णन करेंगे।
बच्चों की संपत्ति विशेष है। सम्मेलन द्वारा, यह हमेशा पहली विशेषता है जिसका अर्थ है कि आप इसे छोड़ सकते हैं।
Html.H1 (बच्चों = 'हैलो डैश') html.H1 ('हैलो डैश') के समान है।
आपके एप्लिकेशन के फ़ॉन्ट यहां प्रदर्शित होने की तुलना में थोड़ा अलग दिखाई देंगे। यह एप्लिकेशन तत्वों की डिफ़ॉल्ट शैलियों को संशोधित करने के लिए एक कस्टम सीएसएस स्टाइलशीट का उपयोग कर रहा है। कस्टम फ़ॉन्ट शैली अनुमेय है, लेकिन अभी तक, हम नीचे दिए गए URL या अपनी पसंद के किसी भी URL को जोड़ सकते हैं -
app.css.append_css ({"external_url":https://codepen.io/chriddyp/pen/bwLwgP.css}) इन उदाहरणों के समान रूप और अनुभव प्राप्त करने के लिए अपनी फ़ाइल प्राप्त करें।
HTML के बारे में अधिक
डैश_एचटीएमएल_कंप्यूटर लाइब्रेरी में प्रत्येक HTML टैग के लिए एक घटक वर्ग के साथ-साथ सभी HTML तर्क के लिए कीवर्ड तर्क शामिल हैं।
आइए हम अपने पिछले ऐप टेक्स्ट में घटकों की इनलाइन शैली जोड़ते हैं -
# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html
app = dash.Dash()
colors = {
'background': '#87D653',
'text': '#ff0033'
}
app.layout = html.Div(style={'backgroundColor': colors['background']}, children=[
html.H1(
children='Hello Dash',
style={
'textAlign': 'center',
'color': colors['text']
}
),
html.Div(children='Dash: A web application framework for Python.', style={
'textAlign': 'center',
'color': colors['text']
}),
dcc.Graph(
id='example-graph-2',
figure={
'data': [
{'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'Delhi'},
{'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Mumbai'},
],
'layout': {
'plot_bgcolor': colors['background'],
'paper_bgcolor': colors['background'],
'font': {
'color': colors['text']
}
}
}
)
])
if __name__ == '__main__':
app.run_server(debug=True)
उपरोक्त उदाहरण में, हमने शैली संपत्ति के साथ html.Div और html.H1 घटकों की इनलाइन शैलियों को संशोधित किया है।
यह डैश एप्लिकेशन में निम्नानुसार प्रस्तुत किया गया है -
डैश_एचटीएमएल_काउंटर और एचटीएमएल विशेषताओं के बीच कुछ महत्वपूर्ण अंतर हैं -
डैश में शैली की संपत्ति के लिए, आप केवल एक शब्दकोश की आपूर्ति कर सकते हैं, जबकि HTML में, यह अर्धविराम से अलग स्ट्रिंग है।
शैली शब्दकोश कुंजी हैं camelCased, इसलिए पाठ-संरेखण में परिवर्तन होता है textalign।
डैश में क्लासनेम HTML क्लास की विशेषता के समान है।
पहला तर्क HTML टैग के बच्चों का है जो बच्चों के कीवर्ड तर्क के माध्यम से निर्दिष्ट किया गया है।
पुन: प्रयोज्य अवयव
पायथन में अपने मार्कअप को लिखकर, हम संदर्भ या भाषा को बदले बिना तालिकाओं जैसे जटिल पुन: प्रयोज्य घटक बना सकते हैं -
नीचे एक त्वरित उदाहरण है जो पांडा डेटाफ्रेम से एक "तालिका" उत्पन्न करता है।
import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd
df = pd.read_csv(
'https://gist.githubusercontent.com/chriddyp/'
'c78bf172206ce24f77d6363a2d754b59/raw/'
'c353e8ef842413cae56ae3920b8fd78468aa4cb2/'
'usa-agricultural-exports-2011.csv')
def generate_table(dataframe, max_rows=10):
return html.Table(
# Header
[html.Tr([html.Th(col) for col in dataframe.columns])] +
# Body
[html.Tr([
html.Td(dataframe.iloc[i][col]) for col in dataframe.columns
]) for i in range(min(len(dataframe), max_rows))]
)
app = dash.Dash()
app.layout = html.Div(children=[
html.H4(children='US Agriculture Exports (2011)'),
generate_table(df)
])
if __name__ == '__main__':
app.run_server(debug=True)
हमारा आउटपुट कुछ इस तरह होगा -
विज़ुअलाइज़ेशन के बारे में अधिक
डैश_कोर_सॉफ़्टर्स लाइब्रेरी में एक घटक शामिल है जिसे कहा जाता है Graph।
ग्राफ़ खुले स्रोत का उपयोग करके इंटरेक्टिव डेटा विज़ुअलाइज़ेशन को प्लॉट करता है। जावास्क्रिप्ट रेखांकन लाइब्रेरी। Plotly.js लगभग 35 चार्ट प्रकारों का समर्थन करता है और वेक्टर-गुणवत्ता वाले SVG और उच्च-प्रदर्शन वाले WebGL दोनों में चार्ट प्रस्तुत करता है।
नीचे एक उदाहरण दिया गया है जो पंडों के डेटाफ्रेम से एक स्कैटर प्लॉट बनाता है -
import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd
import plotly.graph_objs as go
app = dash.Dash()
df = pd.read_csv(
'https://gist.githubusercontent.com/chriddyp/' +
'5d1ea79569ed194d432e56108a04d188/raw/' +
'a9f9e8076b837d541398e999dcbac2b2826a81f8/'+
'gdp-life-exp-2007.csv')
app.layout = html.Div([
dcc.Graph(
id='life-exp-vs-gdp',
figure={
'data': [
go.Scatter(
x=df[df['continent'] == i]['gdp per capita'],
y=df[df['continent'] == i]['life expectancy'],
text=df[df['continent'] == i]['country'],
mode='markers',
opacity=0.7,
marker={
'size': 15,
'line': {'width': 0.5, 'color': 'white'}
},
name=i
) for i in df.continent.unique()
],
'layout': go.Layout(
xaxis={'type': 'log', 'title': 'GDP Per Capita'},
yaxis={'title': 'Life Expectancy'},
margin={'l': 40, 'b': 40, 't': 10, 'r': 10},
legend={'x': 0, 'y': 1},
hovermode='closest'
)
}
)
])
if __name__ == '__main__':
app.run_server()
उपरोक्त कोड का आउटपुट निम्नानुसार है -
ये रेखांकन संवादात्मक और उत्तरदायी हैं। आप उनके मूल्यों को देखने के लिए बिंदुओं पर होवर कर सकते हैं, किंवदंती वस्तुओं पर क्लिक करके निशान टॉगल कर सकते हैं, ज़ूम करने के लिए क्लिक करें और खींचें, शिफ्ट को दबाए रखें और क्लिक करें और पैन पर खींचें।
markdown
हालांकि डैश डैश_ html_compenders लाइब्रेरी के माध्यम से HTML फ्लेवर को उजागर करता है, यह HTML में आपकी कॉपी लिखने के लिए थकाऊ हो सकता है। ग्रंथों के ब्लॉक लिखने के लिए, आप डैश_कोर_सेंटर लाइब्रेरी में मार्कडाउन घटक का उपयोग कर सकते हैं।
प्रमुख घटक
डैश_कोर_कंप्यूटरों में उच्च-स्तरीय घटकों जैसे ड्रॉपडाउन, ग्राफ़, मार्कडाउन, ब्लॉक और कई और अधिक शामिल हैं।
अन्य सभी डैश घटकों की तरह, उन्हें पूरी तरह से घोषित रूप से वर्णित किया गया है। हर विकल्प जो विन्यास योग्य है वह घटक के एक कीवर्ड तर्क के रूप में उपलब्ध है।
नीचे दिए गए कुछ घटकों का उपयोग करके उदाहरण दिया गया है -
# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html
app = dash.Dash()
app.layout = html.Div([
html.Label('Dropdown'),
dcc.Dropdown(
options=[
{'label': 'New York City', 'value': 'NYC'},
{'label': u'Montréal', 'value': 'MTL'},
{'label': 'San Francisco', 'value': 'SF'}
],
value='MTL'
),
html.Label('Multi-Select Dropdown'),
dcc.Dropdown(
options=[
{'label': 'New York City', 'value': 'NYC'},
{'label': u'Montréal', 'value': 'MTL'},
{'label': 'San Francisco', 'value': 'SF'}
],
value=['MTL', 'SF'],
multi=True
),
html.Label('Radio Items'),
dcc.RadioItems(
options=[
{'label': 'New York City', 'value': 'NYC'},
{'label': u'Montréal', 'value': 'MTL'},
{'label': 'San Francisco', 'value': 'SF'}
],
value='MTL'
),
html.Label('Checkboxes'),
dcc.Checklist(
options=[
{'label': 'New York City', 'value': 'NYC'},
{'label': u'Montréal', 'value': 'MTL'},
{'label': 'San Francisco', 'value': 'SF'}
],
values=['MTL', 'SF']
),
html.Label('Text Input'),
dcc.Input(value='MTL', type='text'),
html.Label('Slider'),
dcc.Slider(
min=0,
max=9,
marks={i: 'Label {}'.format(i) if i == 1 else str(i) for i in range(1, 6)},
value=5,
),
], style={'columnCount': 2})
if __name__ == '__main__':
app.run_server(debug=True)
उपरोक्त कार्यक्रम से आउटपुट निम्नानुसार है -
कॉलिंग हेल्प
डैश घटक घोषणात्मक हैं। इन घटकों का प्रत्येक विन्यासनीय पहलू इंस्टालेशन के दौरान एक कीवर्ड तर्क के रूप में सेट किया जाता है। आप किसी घटक के बारे में और उसके उपलब्ध तर्कों के बारे में अधिक जानने के लिए किसी भी घटक पर अपने अजगर कंसोल में मदद कर सकते हैं। उनमें से कुछ नीचे दिए गए हैं -
>>> help(dcc.Dropdown)
Help on class Dropdown in module builtins:
class Dropdown(dash.development.base_component.Component)
| A Dropdown component.
| Dropdown is an interactive dropdown element for selecting one or more
| items.
| The values and labels of the dropdown items are specified in the `options`
| property and the selected item(s) are specified with the `value` property.
|
| Use a dropdown when you have many options (more than 5) or when you are
| constrained for space. Otherwise, you can use RadioItems or a Checklist,
| which have the benefit of showing the users all of the items at once.
|
| Keyword arguments:
| - id (string; optional)
| - options (list; optional): An array of options
| - value (string | list; optional): The value of the input. If `multi` is false (the default)
-- More --
संक्षेप में, डैश ऐप का लेआउट बताता है कि ऐप कैसा दिखता है। लेआउट घटकों का एक श्रेणीबद्ध पेड़ है। डैश_एचटीएमएल_कंप्यूटर लाइब्रेरी सभी एचटीएमएल टैग और कीवर्ड तर्क के लिए कक्षाएं प्रदान करता है, और शैली, क्लासनेम और आईडी जैसी HTML विशेषताओं का वर्णन करता है। डैश_कोर_कंप्यूटर लाइब्रेरी नियंत्रण और ग्राफ़ जैसे उच्च-स्तरीय घटक उत्पन्न करती है।
पायथन वेब फ्रेमवर्क की दुनिया बहुत सारे विकल्प प्रदान करती है। कुछ प्रमुख रूपरेखा पर विचार करने के लिए Django, फ्लास्क, बोतल, डीजल, Web2py, पिरामिड, फाल्कन, पेकन, आदि हैं, जो डेवलपर माइंडशेयर के लिए प्रतिस्पर्धा करते हैं। पिरामिड, Django, Web2py और फ्लास्क जैसे फ्रेमवर्क पेशेवरों और विपक्षों की सूची के साथ आदर्श हैं; अपनी परियोजना के लिए सिर्फ एक का चयन करना एक कठिन विकल्प है।
डैश पूरी तरह से जरूरतों के विभिन्न सेट के लिए डिज़ाइन किया गया है। इसलिए, एक डेवलपर के रूप में आप विकल्पों में से एक को काट देना चाहते हैं जो आपको समय पर और पूर्णता के साथ अपनी परियोजना को पूरा करने में मदद करेगा।
यदि हम फ्लास्क, पिरामिड और Django फ्रेमवर्क की तुलना करते हैं, तो फ्लास्क एक माइक्रो-फ्रेमवर्क है जिसका उद्देश्य मुख्य रूप से सरल आवश्यकताओं वाले छोटे अनुप्रयोगों के लिए है जबकि पिरामिड और Django दोनों बड़े अनुप्रयोगों के उद्देश्य से हैं। पिरामिड लचीलापन और स्वतंत्रता को ध्यान में रखकर बनाया गया है, इसलिए डेवलपर के पास परियोजना के लिए सही उपकरण हैं। पिरामिड के मामले में, डेवलपर डेटाबेस, URL संरचना, अस्थायी शैली और बहुत कुछ चुनने के लिए स्वतंत्र है। हालांकि, Django में सभी बैटरियों को शामिल किया गया है, जो एक वेब एप्लिकेशन की जरूरत है, इसलिए हमें सिर्फ Django को स्थापित करने और काम शुरू करने की आवश्यकता है।
Django एक ORM के साथ आता है, जबकि पिरामिड और फ्लास्क डेवलपर को यह चुनने के लिए छोड़ देते हैं कि वे (या यदि) चाहते हैं कि उनका डेटा संग्रहीत किया जाए। आम तौर पर, गैर-Django वेब अनुप्रयोगों के लिए सबसे आम ORM SQLAlchemy है, हालांकि, अन्य विकल्प DjangoDB, MongoDB, LevelDB और SQLite हो सकते हैं।
एक डेवलपर होने के नाते, अगर मुझे अपने प्रोजेक्ट के लिए Django और Web2py के बीच चयन करना है। मुझे दोनों रूपरेखाओं के लाभों और सीमाओं के बारे में कुछ पता होना चाहिए। तो चलिए Django और Web2py की तुलना करते हैं -
Django
Django का समुदाय एक बड़ा धन है। यह वास्तव में एक डेवलपर का मतलब है संसाधनों का धन अधिक से अधिक होगा। विशेष रूप से, यह नीचे आता है -
- Documentation
- स्रोत स्रोत खोलें
- तृतीय-पक्ष एप्लिकेशन का समर्थन करते हैं
- परिनियोजन समर्थन
- आईआरसी सहायक डेवलपर्स के साथ चैनल
Django के पास विकास टीम और प्रलेखन का एक बहुत बड़ा समुदाय है। यह सही ढांचा है जब हम एक जटिल बैकएंड लिखने के साथ काम कर रहे हैं क्योंकि यह बहुत सारे थर्ड पार्टी ऐप प्रदान करता है जो आपको उपयोगकर्ता के तर्क (साइनअप, प्रमाणीकरण), अतुल्यकालिक कार्यों, एपीआई निर्माण, ब्लॉग्स, आदि जैसी चीजों को स्वचालित करने देता है।
web2py
Web2py सरल वेब ऐप्स या http सर्वर के तेजी से विकास के लिए एक अच्छा फिट है। नीचे web2py के कुछ लाभ और सीमाएं दी गई हैं।
Web2py के लाभ
Web2py ढांचे के कुछ लाभ निम्नलिखित हैं -
विकास की गति और सरलता के मामले में Django और फ्लास्क की तुलना में Web2py एक संभावित ढांचा है। जैसा कि Web2py पायथन-आधारित टेम्पलेट भाषा का उपयोग करता है, यह अजगर डेवलपर्स को लेखन टेम्पलेट की मूल बातें समझने के तुरंत बाद कोड लिखना शुरू करने की अनुमति देता है।
Web2py चल रहे समय को कम करने के लिए एक अनुकूलन के रूप में अजगर संकलित कोड चला सकता है और आपको अपने कोड को एक संकलन फैशन में वितरित करने की अनुमति दे सकता है।
Web2py की सीमाएं
फ्रेमवर्क की कुछ सीमाएँ निम्नलिखित हैं:
Web2py सिद्धांतों का समर्थन करता है, हालांकि यह इकाई परीक्षण का समर्थन नहीं करता है। अब उनके सीमित दायरे के कारण सिद्धांत इष्टतम विकल्प नहीं हैं।
उत्पादन और विकास मोड में कोई अंतर नहीं है। अपवाद होने की स्थिति में, टिकट हर समय उत्पन्न होता है और आपको त्रुटि की जांच करने के लिए टिकट पर नेविगेट करना होगा। यह उत्पादन सर्वर के मामले में मददगार हो सकता है, लेकिन विकास के माहौल में मुश्किल होगा क्योंकि डेवलपर्स को टिकट नंबर की जांच करने के बजाय तुरंत त्रुटि देखने की आवश्यकता होती है।
Web2py में एक अच्छा डेटाबेस अमूर्त परत (डीएएल) है जो आपको कई प्रकार के डेटाबेस इंजनों को सार करने की अनुमति देता है लेकिन इसमें शक्तिशाली एमएम का अभाव है। यदि आप अपेक्षाकृत बड़े मॉडल के साथ काम कर रहे हैं, तो आपका कोड सभी नेस्टेड परिभाषाओं और विशेषताओं से बिखर जाएगा जो चीजों को जटिल बनाता है।
हम संशोधनों के बिना मानक अजगर विकास उपकरण का उपयोग नहीं कर सकते क्योंकि web2py में वास्तव में खराब आईडीई समर्थन है।
Django और Web2py फ्रेमवर्क पूर्ण स्टैक फ्रेमवर्क हैं। इसका मतलब है कि वे आवश्यक सभी कोड प्रदान करते हैं - फॉर्म जनरेटर से लेकर टेम्प्लेटिंग लेआउट और सत्यापन के रूप में, और आपको अपनी विशिष्ट आवश्यकताओं के अनुसार चीजें लिखने के लिए छोड़ देते हैं।
हालांकि, फ्लास्क और पिरामिड जैसे गैर-स्टैक फ्रेमवर्क के साथ, यदि आप एक पूर्ण विशेषताओं वाली वेबसाइट बनाना चाहते हैं, तो आपको बहुत सारे कोड और अतिरिक्त बिट्स को स्वयं जोड़ना होगा। इसमें बहुत कौशल और समय लगता है।
पानी का छींटा
डैश पूरी तरह से डैशबोर्ड के लिए प्रतिक्रियाशील ढांचे के निर्माण के विशिष्ट कार्य के लिए डिज़ाइन किया गया है। डैश बाय प्लॉटली डेवलपर डेवलपर के लिए एक शानदार तरीका है जिससे वह जावास्क्रिप्ट और फ्रंट वेब वेब डेवलपमेंट सीखे बिना इंटरैक्टिव वेब ऐप बना सकता है। डैश फ्लास्क, प्लॉटली.जेएस, रिएक्ट और रिएक्ट जेएस के शीर्ष पर बनाया गया है।
डैश और अन्य रूपरेखाओं (ऊपर उल्लिखित) के बीच कोई तुलना नहीं है क्योंकि वे विभिन्न श्रेणियों के फ्रेमवर्क से संबंधित हैं। नीचे कुछ अन्य इंटरएक्टिव डैशबोर्ड फ्रेमवर्क (बृहस्पति डैशबोर्ड, मैटप्लोटिब और अन्य) पर डैश पसंद करने के कुछ कारण दिए गए हैं:
कोड की सिर्फ 50 लाइनों के साथ, आप एक सरल "हैलो वर्ल्ड" डैश ऐप लिख सकते हैं, क्योंकि डैश के लिए बहुत कम बॉयलरप्लेटर की आवश्यकता होती है।
पूरी दुनिया में सबसे ज्यादा पसंद की जाने वाली भाषा में एंटायर डैश एप्स को अजगर भाषा में लिखा गया है।
अपने स्वयं के अजगर कोड में, आप ड्रॉपडाउन, पाठ इनपुट, स्लाइडर्स और प्रतिक्रियाशील डैश "कॉलबैक" के साथ रेखांकन जैसे इंटरैक्टिव घटकों को बांध सकते हैं।
डैश ऐप्स में जटिल यूआई में कई इनपुट, कई आउटपुट और इनपुट हो सकते हैं जो अन्य इनपुट पर निर्भर करते हैं।
इसके साथ ही, कई उपयोगकर्ता डैश ऐप पर काम कर सकते हैं।
React के साथ अपने स्वयं के डैश घटक बनाने के लिए, डैश घटकों को रेंडर करने के लिए React.js का उपयोग करता है और इसमें एक प्लगइन सिस्टम शामिल होता है।
डेवलपर्स या लेखक डैश ऐप्स लिख सकते हैं जो डैश के ग्राफ़ घटकों के इंटरैक्टिव होने के साथ-साथ ग्राफ़ पर बिंदुओं पर क्लिक करने, मंडराने या चयन करने का जवाब देते हैं।
निष्कर्ष
हम यह निष्कर्ष निकाल सकते हैं कि कई उपलब्ध पायथन फ्रेमवर्क में से सही रूपरेखा को चुनना पूरी तरह से परियोजना के प्रकार, जटिलता, छोटे या उद्यम स्तर की परियोजना, उपलब्ध समुदाय के समर्थन या ऑनलाइन संसाधन उपलब्ध, स्केलेबिलिटी, सुरक्षा, आदि पर निर्भर करता है।
उपर्युक्त अजगर ढांचे अपने वर्ग में सबसे अच्छे हैं, लेकिन उनके अपने लाभ और कमियां हैं (परियोजना की आवश्यकता के आधार पर)। तो, एक प्रकार की रूपरेखा सभी प्रकार की परियोजनाओं के लिए उपयुक्त नहीं है।