Python Liquid
Python Liquid is a Python engine for Liquid, the safe, customer-facing template language for flexible web apps.
This page gets you started using Liquid with Python. See Introduction to Liquid, the filter reference and the tag reference to learn about writing Liquid templates.
Quick start
Install
Install Python Liquid from PyPi:
- pip
- pipenv
- poetry
python -m pip install -U python-liquid
pipenv install python-liquid
poetry add python-liquid
Or conda-forge:
- anaconda
- miniconda
- miniforge
- mamba
conda install -c conda-forge python-liquid
conda install -c conda-forge python-liquid
conda install python-liquid
mamba install python-liquid
Render
Render a template string by creating a Template
and calling its render()
method.
from liquid import Template
template = Template("Hello, {{ you }}!")
print(template.render(you="World")) # Hello, World!
print(template.render(you="Liquid")) # Hello, Liquid!
Keyword arguments passed to render()
are available as variables for templates to use in Liquid expressions.
from liquid import Template
template = Template(
"{% for person in people %}"
"Hello, {{ person.name }}!\n"
"{% endfor %}"
)
data = {
"people": [
{"name": "John"},
{"name": "Sally"},
]
}
print(template.render(**data))
# Hello, John!
# Hello, Sally!
Configure
Configure template parsing and rendering behavior with extra arguments to Template
. The following example renders a template in strict mode and will raise an exception whenever an undefined variable is used. See liquid.Template
for all available options.
from liquid import Template
from liquid import Mode
from liquid import StrictUndefined
template = Template(
"Hello, {{ you }}!",
tolerance=Mode.STRICT,
undefined=StrictUndefined,
)
result = template.render(you="World")
Keep reading to see how to configure an environment once, then load and render templates from it.
Environment
While Template
can be convenient, more often than not an application will want to configure a single Environment
, then load and render templates from it. This is usually more efficient than using Template
directly.
All templates rendered from an Environment
will share the environment's configuration. See liquid.Environment
for all available options. Notice that Environment
accepts a loader
argument, whereas Template
does not.
from liquid import Environment
from liquid import Mode
from liquid import StrictUndefined
from liquid import FileSystemLoader
env = Environment(
tolerance=Mode.STRICT,
undefined=StrictUndefined,
loader=FileSystemLoader("./templates/"),
)
template = env.from_string("Hello, {{ you }}!")
result = template.render(you="World")