官术网_书友最值得收藏!

Templates

Sending back JSON or YAML documents is easy enough, since we're just serializing data. And most microservices produce machine-parseable data. But in some cases, we might need to create documents with some layout--whether it's an HTML page, or a PDF report, or an email.

For anything that's text-based, Flask integrates a template engine called Jinja (http://jinja.pocoo.org). The main reason Flask incorporates Jinja is to produce HTML documents, so you will find helpers like render_template, which generate responses by picking a Jinja template, and provide the output given some data.

But Jinja is not unique to HTML or other tag-based documents. It can create any document as long as it's text-based.

For example, if your microservice sends emails, instead of relying on the standard library's email package to produce the email content, which can be cumbersome, you could use Jinja.

The following is an example of an email template:

Date: {{date}} 
From: {{from}}
Subject: {{subject}}
To: {{to}}
Content-Type: text/plain


Hello {{name}},

We have received your payment!

Below is the list of items we will deliver for lunch:

{% for item in items %}- {{item['name']}} ({{item['price']}} Euros)
{% endfor %}

Thank you for your business!

--
Tarek's Burger

Jinja uses double brackets for marking variables that will be replaced by a value. Variables can be anything that's passed to Jinja at execution time.

You can also use Python's if and for blocks directly in your templates with the {% for x in y % }... {% endfor %} and {% if x %}...{% endif %} notations.

The following is a Python script that uses the email template to produce an entirely valid RFC 822 message, which you can send via SMTP:

    from datetime import datetime 
from jinja2 import Template
from email.utils import format_datetime

def render_email(**data):
with open('email_template.eml') as f:
template = Template(f.read())
return template.render(**data)

data = {'date': format_datetime(datetime.now()),
'to': 'bob@example.com',
'from': 'tarek@ziade.org',
'subject': "Your Tarek's Burger order",
'name': 'Bob',
'items': [{'name': 'Cheeseburger', 'price': 4.5},
{'name': 'Fries', 'price': 2.},
{'name': 'Root Beer', 'price': 3.}]}

print(render_email(**data))

The render_email function uses the Template class to generate the email using the provided data.

Jinja is quite powerful, and comes with many features we won't describe here, since it's out of the chapter's scope. But if you need to do some templating work in your microservices, it's a good choice, and it's present in Flask. Check out http://jinja.pocoo.org/docs for a full documentation on Jinja features.
主站蜘蛛池模板: 安达市| 阿图什市| 崇义县| 望城县| 韶关市| 科技| 南皮县| 上高县| 辉县市| 满城县| 堆龙德庆县| 博客| 成安县| 中江县| 昌黎县| 象州县| 青浦区| 兰考县| 天全县| 大埔县| 吕梁市| 老河口市| 巧家县| 临沭县| 噶尔县| 离岛区| 桂林市| 临漳县| 绥化市| 临颍县| 沂南县| 云安县| 伊通| 确山县| 洛隆县| 湟源县| 嘉鱼县| 长宁区| 南投县| 嘉兴市| 绥芬河市|