फ्लास्क - टेम्पलेट

HTML के रूप में एक निश्चित URL से जुड़े फ़ंक्शन के आउटपुट को वापस करना संभव है। उदाहरण के लिए, निम्न स्क्रिप्ट में,hello() समारोह प्रदान करेगा ‘Hello World’ साथ में <h1> इससे जुड़ा टैग।

from flask import Flask
app = Flask(__name__)

@app.route('/')
def index():
   return '<html><body><h1>Hello World</h1></body></html>'

if __name__ == '__main__':
   app.run(debug = True)

हालाँकि, Python कोड से HTML कंटेंट जेनरेट करना बोझिल होता है, खासकर तब जब वेरिएबल या लूप्स जैसे वेरिएबल डेटा और Python लैंग्वेज एलिमेंट डालने की जरूरत होती है। इसके लिए HTML से बार-बार भागने की आवश्यकता होगी।

यह वह जगह है जहाँ कोई लाभ ले सकता है Jinja2टेम्पलेट इंजन, जिस पर फ्लास्क आधारित है। फ़ंक्शन से हार्डकोड HTML वापस करने के बजाय, एक HTML फ़ाइल द्वारा प्रस्तुत किया जा सकता हैrender_template() समारोह।

from flask import Flask
app = Flask(__name__)

@app.route('/')
def index():
   return render_template(‘hello.html’)

if __name__ == '__main__':
   app.run(debug = True)

फ्लास्क टेम्पलेट फ़ोल्डर में HTML फ़ाइल को खोजने की कोशिश करेगा, उसी फ़ोल्डर में जिसमें यह स्क्रिप्ट मौजूद है।

  • एप्लिकेशन फ़ोल्डर
    • Hello.py
    • templates
      • hello.html

अवधि ‘web templating system’एक HTML स्क्रिप्ट डिजाइन करने के लिए संदर्भित करता है जिसमें चर डेटा गतिशील रूप से डाला जा सकता है। एक वेब टेम्पलेट सिस्टम में एक टेम्पलेट इंजन, कुछ प्रकार के डेटा स्रोत और एक टेम्पलेट प्रोसेसर शामिल होता है।

फ्लास्क का उपयोग करता है jinja2टेम्पलेट इंजन। वेब टेम्प्लेट में वैरिएबल और एक्सप्रेशंस के लिए HTML सिंटेक्स इंटरसेप्ड प्लेसहोल्डर्स होते हैं (इन पाइथन एक्सप्रेशंस में) जो टेम्प्लेट दिए जाने पर वैल्यूज को रिप्लेस कर दिया जाता है।

निम्न कोड के रूप में सहेजा गया है hello.html टेम्पलेट फ़ोल्डर में।

<!doctype html>
<html>
   <body>
   
      <h1>Hello {{ name }}!</h1>
      
   </body>
</html>

अगला, पायथन शेल से निम्न स्क्रिप्ट चलाएँ।

from flask import Flask, render_template
app = Flask(__name__)

@app.route('/hello/<user>')
def hello_name(user):
   return render_template('hello.html', name = user)

if __name__ == '__main__':
   app.run(debug = True)

जैसे ही विकास सर्वर चलना शुरू होता है, ब्राउज़र खोलें और URL दर्ज करें - http://localhost:5000/hello/mvl

variable URL का कुछ भाग डाला जाता है {{ name }} स्थान रखने वाला।

jinja2 टेम्पलेट इंजन HTML से बचने के लिए निम्नलिखित सीमांकक का उपयोग करता है।

  • कथन के लिए {% ...%}
  • खाका आउटपुट पर प्रिंट करने के लिए एक्सप्रेशन के लिए {{...}}
  • {# ... #} टिप्पणियों के लिए टेम्पलेट आउटपुट में शामिल नहीं हैं
  • लाइन स्टेटमेंट के लिए # ... ##

निम्नलिखित उदाहरण में, टेम्पलेट में सशर्त विवरण का उपयोग प्रदर्शित किया गया है। के लिए URL नियमhello()फ़ंक्शन पूर्णांक पैरामीटर को स्वीकार करता है। इसे पास किया जाता हैhello.htmlटेम्पलेट। इसके अंदर, प्राप्त संख्या (अंकों) के मूल्य की तुलना (50 से अधिक या कम) की जाती है और तदनुसार HTML को सशर्त रूप से प्रदान किया जाता है।

पायथन लिपि इस प्रकार है -

from flask import Flask, render_template
app = Flask(__name__)

@app.route('/hello/<int:score>')
def hello_name(score):
   return render_template('hello.html', marks = score)

if __name__ == '__main__':
   app.run(debug = True)

HTML टेम्पलेट की स्क्रिप्ट hello.html इस प्रकार है -

<!doctype html>
<html>
   <body>
      {% if marks>50 %}
         <h1> Your result is pass!</h1>
      {% else %}
         <h1>Your result is fail</h1>
      {% endif %}
   </body>
</html>

ध्यान दें कि सशर्त बयान if-else तथा endif परिसीमन में संलग्न हैं {%..%}

पायथन स्क्रिप्ट चलाएं और URL पर जाएं http://localhost/hello/60 और फिर http://localhost/hello/30 सशर्त रूप से HTML के आउटपुट को देखने के लिए।

पायथन लूप निर्माण को टेम्पलेट के अंदर भी नियोजित किया जा सकता है। निम्नलिखित लिपि में, एresult() समारोह टेम्पलेट में एक शब्दकोश वस्तु भेजता है results.html जब यूआरएल http://localhost:5000/result ब्राउज़र में खोला गया है।

का साँचा हिस्सा result.html एक काम करता है for loop शब्दकोश वस्तु की कुंजी और मूल्य जोड़े प्रदान करने के लिए result{} एक HTML तालिका की कोशिकाओं के रूप में।

पायथन शेल से निम्न कोड चलाएँ।

from flask import Flask, render_template
app = Flask(__name__)

@app.route('/result')
def result():
   dict = {'phy':50,'che':60,'maths':70}
   return render_template('result.html', result = dict)

if __name__ == '__main__':
   app.run(debug = True)

निम्न HTML स्क्रिप्ट को इस रूप में सहेजें result.html टेम्पलेट फ़ोल्डर में।

<!doctype html>
<html>
   <body>
      <table border = 1>
         {% for key, value in result.items() %}
            <tr>
               <th> {{ key }} </th>
               <td> {{ value }} </td>
            </tr>
         {% endfor %}
      </table>
   </body>
</html>

यहाँ, फिर से पायथन बयान इसी के लिए For लूप {% ..%} में संलग्न हैं, जबकि भाव key and value अंदर डाल रहे हैं {{ }}

विकास के चलने के बाद, खुला http://localhost:5000/result निम्न आउटपुट प्राप्त करने के लिए ब्राउज़र में।