Sophie

Sophie

distrib > Fedora > 14 > i386 > media > os > by-pkgid > 5c4f8358fd6fdc210fb0d926bd25802c > files > 194

python-werkzeug-doc-0.6.2-2.fc14.noarch.rpm

==============
Mini Templates
==============

.. module:: werkzeug

Werkzeug ships a **minimal** templating system which is useful for small
scripts where you just want to generate some HTML and don't want another
dependency or full blown template engine system.

It it however not recommended to use this template system for anything else
than simple content generation.  The :class:`Template` class can be directly
imported from the :mod:`werkzeug` module.

The template engine recognizes ASP/PHP like blocks and executes the code
in them::

    t = Template('<% for u in users %>${u["username"]}\n<% endfor %>')
    t.render(users=[{'username': 'John'},
                    {'username': 'Jane'}])

would result in::

    John
    Jane

You can also create templates from files::

    t = Template.from_file('test.html')

The syntax elements are a mixture of django, genshi text and mod_python
templates and used internally in werkzeug components.

We do not recommend using this template engine in a real environment
because is quite slow and does not provide any advanced features.  For
simple applications (cgi script like) this can however be sufficient.


Syntax Elements
===============

Printing Variables:

.. sourcecode:: text

    $variable
    $variable.attribute[item](some, function)(calls)
    ${expression} or <%py print expression %>

Keep in mind that the print statement adds a newline after the call or
a whitespace if it ends with a comma.

For Loops:

.. sourcecode:: text

    <% for item in seq %>
        ...
    <% endfor %>

While Loops:

.. sourcecode:: text

    <% while expression %>
        <%py break / continue %>
    <% endwhile %>

If Conditions:

.. sourcecode:: text

    <% if expression %>
        ...
    <% elif expression %>
        ...
    <% else %>
        ...
    <% endif %>

Python Expressions:

.. sourcecode:: text

    <%py
        ...
    %>

    <%python
        ...
    %>

Note on python expressions:  You cannot start a loop in a python block
and continue it in another one.  This example does *not* work:

.. sourcecode:: text

    <%python
        for item in seq:
    %>
        ...

Comments:

.. sourcecode:: text

    <%#
        This is a comment
    %>


Missing Variables
=================

If you try to access a missing variable you will get back an `Undefined`
object.  You can iterate over such an object or print it and it won't
fail.  However every other operation will raise an error.  To test if a
variable is undefined you can use this expression:

.. sourcecode:: text

    <% if variable is Undefined %>
        ...
    <% endif %>


The Template Class
==================

.. autoclass:: Template

   Besides the normal global functions and objects, the following functions
   are added to every namespace: `escape`, `url_encode`, `url_quote`, and
   `url_quote_plus`.  You can change those by subclassing `Template` and
   overriding the `default_context` dict::

       class MyTemplate(Template):
           default_namespace = {
               'ueber_func':       ueber_func
           }
           # Now add the old functions, too, because they are useful.
           default_namespace.update(Template.default_namespace)

   .. automethod:: from_file

   .. automethod:: render([context])