Skip to content

(Japanese) 🎷 Django テンプレートタグまとめ: ウェブアプリケーションフレームワーク Django のコアが提供するテンプレートタグ・テンプレートフィルタの一覧です。

Notifications You must be signed in to change notification settings

dynojp/django-templatetags-ja

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 

Repository files navigation

Django テンプレートタグまとめ

ウェブアプリケーションフレームワーク Django のコアが提供するテンプレートタグ・テンプレートフィルタの一覧です。

このリストには Django コアが提供するすべてのタグ・フィルタが載っています。 順序は辞書順です。 対象の Django のバージョンは 3.0 です。 サンプルコードの大半は公式ドキュメントのものです。

テンプレートタグ

autoescape

HTML のエスケープの有効・無効を切り替えます。

{% autoescape on %}
    {{ body }}
{% endautoescape %}

デフォルトではエスケープは有効になっています。

block

extends タグを使って他のテンプレートを継承したときに特定のブロックの中身を書き換えます。

{% extends "base.html" %}

{% block main_content %}
{% endblock main_content %}

endblock の後の名前は付けても付けなくても問題ありません。

継承元の内容を上書きするのではなく追加したいときは block.super 変数を使用します。

{% extends "base.html" %}

{% block breadcrumbs %}
{{ block.super }} / {{ title }}
{% endblock breadcrumbs %}

blocktrans

範囲内の文字列を翻訳対象にします。

{% blocktrans with book_t=book|title author_t=author|title %}
This is {{ book_t }} by {{ author_t }}
{% endblocktrans %}

変数は with の後に渡します。

cache

範囲内の文字列をキャッシュします。

{% load cache %}
{% cache 500 sidebar %}
    .. sidebar ..
{% endcache %}

最低限 2 つの引数を受け取ります。 ひとつめはキャッシュタイムアウト時間、ふたつめはキャッシュフラグメントの名前です。 キャッシュフラグメントはそのまま文字として認識されるので、変数を使うことはできません。

ユーザーグループやユーザーの単位でキャッシュを分けたい場合は、第 3 引数以降を使用します。

{% load cache %}
{% cache 500 sidebar request.user.username %}
    .. sidebar for logged in user ..
{% endcache %}

デフォルトでキャッシュバックエンドには template_fragments という名前のものがあればそれが使われます。 存在しない場合は default が使われます。

これが必要な場面は稀だと思いますが、 using キーワード引数を使って他のキャッシュバックエンドを指定することもできます。

{% cache 300 local-thing ...  using="localcache" %}

キャッシュについては奥が深いので公式ページの説明もチェックしてください。

comment

範囲内のコードをコメント扱いにして無視します(出力しません)。

{% comment "Optional note" %}
    <p>Commented out text with {{ create_date|date:"c" }}</p>
{% endcomment %}

オプションでメモ用の文字列を渡すことができます。

単一行のコメントは {# これはコメントです #} で、複数行のコメントは comment タグでと使い分けるとよいと思います。

csrf_token

CSRF (クロスサイトリクエストフォージェリ)保護のための <input type="hidden" /> タグを出力します。

<form method="post">{% csrf_token %}
</form>

Django の CSRF 保護機能について詳しくは次のページをご覧ください。

cycle

渡された文字列を順番に出力します。

{% for item in item_list %}
    <tr class="{% cycle "odd" "even" %}">
        ...
    </tr>
{% endfor %}

主にループの中で使用します。

debug

デバッグ情報を出力します。

<textarea> {% filter force_escape %} {% debug %} {% endfilter %} </textarea>

そのままでは <> がエスケープされずに出力されるためページ上にうまく表示されません。 ページ上で確認したいときは {% filter force_escape %}{% endfilter %} 等をあわせて使うと便利です。

ただし、デバッグ情報の出力にはこの debug タグではなく django-debug-toolbar がよく使われます。

extends

他のテンプレートを継承します。

{% extends "base.html" %}
{% extends "blog/article_list.html" %}

テンプレート名はテンプレートローダーのルートディレクトリからのパスで指定します。 ./ または ../ から始めることで、現在のテンプレートからの相対パスでも指定できます。

通常は block タグと併用してブロックの内容を上書きして使用します。

filter

範囲内の文字列にフィルタをかけます。

{% filter force_escape|lower %}
    This text will be HTML-escaped, and will appear in all lowercase.
{% endfilter %}

| でつないで複数のフィルタをかけることができます。

firstof

渡された引数の中から bool() に渡したときの戻り値が False にならない最初の要素を返します。

{% firstof var1 var2 var3 %}

結果をそのまま出力するのではなく後で利用したいときは as を使って変数に格納します。

{% firstof var1 var2 var3 as value %}

for

iterable なオブジェクトに対してループを回します。

<ul>
{% for athlete in athlete_list %}
    <li>{{ athlete.name }}</li>
{% endfor %}
</ul>

末尾の方から要素を取り出したいときは {% for obj in list reversed %}reversed を付けます。

例えば dict に対してループを回したいときは次のようにします。

{% for key, value in data.items %}
    {{ key }}: {{ value }}
{% endfor %}

for から endfor の間では以下の変数を格納した forloop オブジェクトが利用できます。

アトリビュート 内容
forloop.counter 1 始まりのカウンタ
forloop.counter0 0 始まりのカウンタ
forloop.revcounter 1 で終わる逆順のカウンタ
forloop.revcounter0 0 で終わる逆順のカウンタ
forloop.first 最初の要素では True 、その他は False
forloop.last 最後の要素では True 、その他は False
forloop.parentloop ネストされたループにおける親の forloop オブジェクト

例:

{# 1 から順番にカウントアップする #}
<ul>
{% for athlete in athlete_list %}
    <li>{{ forloop.counter }}: {{ athlete.name }}</li>
{% endfor %}
</ul>

forempty

for タグには empty タグを付けて、 iterable が空の場合のみ出力する文字列を指定することができます。

<ul>
{% for gu in gu_list %}
    <li>{{ gu.name }}</li>
{% empty %}
    <li>具はありません。</li>
{% endfor %}
</ul>

get_available_languages

利用可能な言語の一覧を返します。

{% load i18n %}
{% get_available_languages as languages %}
{{ languages }}

各要素はひとつめが言語コード、ふたつめが言語名の 2 要素の tuple です。 as を使って変数名を指定する必要があります。

get_current_language

現在アクティブになっている言語の言語コードを返します。

{% load i18n %}
{% get_current_language as language %}
{{ language }}
{# "ja" #}

言語コードは例えば日本語の場合は ja です。 as を使って変数名を指定する必要があります。

get_current_language_bidi

現在アクティブになっている言語が右から左に読む言語(アラビア語等)の場合のみ True を返します。

{% load i18n %}
{% get_current_language_bidi as language %}
{{ language }}
{# False #}

get_language_info

for で指定された言語コードの言語情報を返します。

{% block content_main_body %}
{% load i18n %}
{% get_language_info for "tr" as lang_info %}

戻り値は以下の情報を持つオブジェクトです。

アトリビュート 内容
lang_info.code 言語コード
lang_info.name_local ローカルな名前
lang_info.name 英語での名前
lang_info.bidi 右から左に読む言語かどうか
lang_info.name_translated アクティブな言語での名前

get_language_info_list

for で指定された言語コードに対応する言語情報の一覧を返します。

{% load i18n %}
{% get_language_info_list for lang_codes as lang_infos %}
{% for lang_info in lang_infos %}
    {{ ... }}
{% endfor %}

戻り値は get_language_info の戻り値と同等のオブジェクトを要素に持つ list です。

get_media_prefix

設定項目 MEDIA_URL で設定されたメディアプリフィクスを返します。

{% load static %}
<body data-media-url="{% get_media_prefix %}">
{% "/media/"%}

get_static_prefix

設定項目 STATIC_URL で設定されたスタティックファイルのプリフィクスを返します。

{% load static %}
{% get_static_prefix as STATIC_PREFIX %}

<img src="{{ STATIC_PREFIX }}images/hi.jpg" alt="Hi!">
<img src="{{ STATIC_PREFIX }}images/hi2.jpg" alt="Hello!">

通常スタティックファイルの URL を出力したいときはテンプレートタグ static を使用するべきです。

if

変数の値によって出力する文字列を切り替えます。

{% if athlete_list %}
    Number of athletes: {{ athlete_list|length }}
{% elif athlete_in_locker_room_list %}
    Athletes should be out of the locker room soon!
{% else %}
    No athletes.
{% endif %}

if の後に渡された変数が存在してなおかつ truthy なら(= bool() に渡したときの戻り値が False なら)、 endif までのブロックの中身を出力します。

Python と同じように elif else を使うこともできます。

ifchanged

値がループのひとつ前の周から変更されたかどうかをチェックします。

引数を渡すかどうかで挙動が異なります。

引数が渡されなかった場合は、 ifchanged から endifchanged までの内容がループのひとつ前の周と異なる場合のみその内容を出力します。 次の例では、日付の一覧を出力する中で、月が変わったときにのみ月の見出し( {{ date|date:"F" }} )を出力します。

<h1>Archive for {{ year }}</h1>

{% for date in days %}
    {% ifchanged %}<h3>{{ date|date:"F" }}</h3>{% endifchanged %}
    <a href="{{ date|date:"M/d"|lower }}/">{{ date|date:"j" }}</a>
{% endfor %}

引数が渡された場合は、渡された引数がループのひとつ前の周と変わった場合のみ ifchanged から endifchanged までの内容を出力します。 次の例では、日付と時刻の一覧を出力する中で、日付が変わったときにのみ日付を出力します。

{% for date in days %}
    {% ifchanged date.date %} {{ date.date }} {% endifchanged %}
    {% ifchanged date.hour date.date %}
        {{ date.hour }}
    {% endifchanged %}
{% endfor %}

ifequal / ifnotequal

ifequalifnotequal は 2 つの変数の値が等しいかどうかで出力内容を変更するためのタグですが、どちらも if で等価なコードが書けるため deprecated となっています。

{% if a == b %}
    ...
{% else %}
    ...
{% endif %}

include

他のテンプレートを読み込みます。

{% include "sidebar.html" %}

読み込まれたテンプレートでは読み込み側のコンテキストがそのまま利用できます。

with を使うとコンテキストを追加(または上書き)することができます。

{% include "sidebar.html" with page_type="detail" %}

with の末尾に only をつけると、読み込まれた方のテンプレートでは明示的に渡されたコンテキストのみが利用できます。

{% include "sidebar.html" with page_type="detail" only %}

load

カスタムテンプレートタグのセットを読み込みます。

{% load static %}

{% get_media_prefix %}

次のようにネストされたテンプレートタグのセットを読み込むには . を使用します。

blogs/
    templatetags/
        articles/
            __init__.py
            utils.py
        __init__.py
    ...
{% load articles.utils %}

from を使えば特定のタグやフィルタだけを個別に読み込むこともできます。

{% load get_media_prefix get_static_prefix from static %}

{% get_media_prefix %}
{% get_static_prefix %}

複数のタグセットをまとめて読み込むこともできます。

{% load static i18n %}

localize

範囲内の変数のローカライズの有効・無効を切り替えます。

{% load l10n %}

{% localize on %}
    {{ value }}
{% endlocalize %}

{% localize off %}
    {{ value }}
{% endlocalize %}

設定項目 USE_L10N よりも細かい粒度での制御ができます。

lorem

ランダムな "lorem ipsum" ラテン語テキストを表示します。

{% lorem [count] [method] [random] %}

オプション引数の意味合いは次のとおりです。

  • count: 要素数。デフォルトは 1 。
  • method: w は単語を、 p は HTML パラグラフ( <p> )を、 b はプレーンテキストのパラグラフブロックを出力する。
  • random: random が渡されたときはランダムな文字列を、渡されなかったときは固定の文字列を出力する。

使用例:

{# プレーンテキストのパラグラフを 1 つ出力する #}
{% lorem %}

{# HTML のパラグラフを 10 個出力する #}
{% lorem 10 p %}

{# 単語を 20 個ランダムで出力する #}
{% lorem 20 w random %}

now

現在の日時を指定されたフォーマットで出力します。

現在の日時は {% now "Y/m/d H:i:s" %} です。

以下のいずれかの設定項目で定義されたフォーマットを使うこともできます。

  • DATE_FORMAT
  • DATETIME_FORMAT
  • SHORT_DATE_FORMAT
  • SHORT_DATETIME_FORMAT

例:

本日の日付は {% now "DATE_FORMAT" %} です。

as を使うことで結果を変数に格納し別の場所で利用することもできます。

{% now "Y" as current_year %}
{% blocktrans %}Copyright {{ current_year }}{% endblocktrans %}

regroup

共通のアトリビュートを持ったオブジェクトからなる list をアトリビュートの値でグルーピングします。

文章での説明よりも例の方がわかりやすいです。 次のような list 変数 cities があるときに

cities = [
    {'name': 'Mumbai', 'population': '19,000,000', 'country': 'India'},
    {'name': 'Calcutta', 'population': '15,000,000', 'country': 'India'},
    {'name': 'New York', 'population': '20,000,000', 'country': 'USA'},
    {'name': 'Chicago', 'population': '7,000,000', 'country': 'USA'},
    {'name': 'Tokyo', 'population': '33,000,000', 'country': 'Japan'},
]

regroup タグを使えば次のようなリストを表す HTML を比較的かんたんに生成することができます。

  • India
    • Mumbai: 19,000,000
    • Calcutta: 15,000,000
  • USA
    • New York: 20,000,000
    • Chicago: 7,000,000
  • Japan
    • Tokyo: 33,000,000

具体的なコードは次のとおりです。

{% regroup cities by country as country_list %}

<ul>
{% for country in country_list %}
    <li>{{ country.grouper }}
    <ul>
        {% for city in country.list %}
          <li>{{ city.name }}: {{ city.population }}</li>
        {% endfor %}
    </ul>
    </li>
{% endfor %}
</ul>

regroup の戻り値 country_list は、各要素が GroupedResult オブジェクトの list です。 GroupedResult オブジェクトは grouperlist という 2 つのフィールドを持つ namedtuple です。

GroupedResult オブジェクトは namedtuple なので、同じ処理を次のような形でも記述できます。

{% regroup cities by country as country_list %}

<ul>
{% for country, local_cities in country_list %}
    <li>{{ country }}
    <ul>
        {% for city in local_cities %}
          <li>{{ city.name }}: {{ city.population }}</li>
        {% endfor %}
    </ul>
    </li>
{% endfor %}
</ul>

グルーピングのキーには、アトリビュートだけでなく、参照先のオブジェクトのアトリビュートや、引数を持たないメソッド等を使用することも可能です。

regroup は元の値がグルーピングのキーに使われるアトリビュートでソート済みでないと正しく動かないので注意が必要です(自動的に対象のアトリビュートでソートしてからグルーピングしてくれるわけではありません)。

resetcycle

cycle タグのループを初期状態にリセットします。

例えば次のようにすると、各 coach の最初の <p> タグのクラスが必ず odd になります。

{% for coach in coach_list %}
    <h1>{{ coach.name }}</h1>
    {% for athlete in coach.athlete_set.all %}
        <p class="{% cycle 'odd' 'even' %}">{{ athlete.name }}</p>
    {% endfor %}
    {% resetcycle %}
{% endfor %}

複数の cycle のループが回っている場合は、 cycleas を付けて名前を付けることにより、特定の cycle だけをリセットすることができます。

{% for item in list %}
    <p class="{% cycle 'odd' 'even' as stripe %} {% cycle 'major' 'minor' 'minor' 'minor' 'minor' as tick %}">
        {{ item.data }}
    </p>
    {% ifchanged item.category %}
        <h1>{{ item.category }}</h1>
        {% if not forloop.first %}{% resetcycle tick %}{% endif %}
    {% endifchanged %}
{% endfor %}

spaceless

範囲内の空白文字を除去します。

{% spaceless %}
    <p>
        <a href="foo/">あ い う </a>
    </p>
{% endspaceless %}

上のコードは次の HTML を出力します。

<p><a href="foo/">あ い う </a></p>

タブ文字や改行も除去対象に含まれます。

ただし、除去されるのはタグとタグの間の空白文字だけです。 タグとテキストの間、テキストとテキストの間の空白文字は除去されません。

static

設定項目 STATIC_ROOT 以下のスタティックファイルに対応する URL を生成します。

{% load static %}
<img src="{% static "images/hi.jpg" %}" alt="Hi!">

その場で出力したくない場合は as を使えば出力せずに変数に格納できます。

{% static "images/hi.jpg" as myphoto %}
<img src="{{ myphoto }}">

templatetag

Django テンプレートにおける特殊な文字列を出力します。

{% templatetag openblock %} url 'entry_list' {% templatetag closeblock %}

上のコードは次の HTML を出力します。

{% url 'entry_list' %}
引数 出力
openblock {%
closeblock %}
openvariable {{
closevariable }}
openbrace {
closebrace }
opencomment {#
closecomment #}

trans

対象の文字列の翻訳を出力します。

{% load i18n %}
<title>{% trans "This is the title." %}</title>

内部的には django.utils.translation.gettext() を使用します。

trans はテンプレート変数を含むテキストの翻訳には使えません。 テンプレート変数を含むテキストの翻訳には blocktrans を使用してください。

翻訳後の文字列を複数箇所で使いたい場合は as を使って変数に格納できます。

{% load i18n %}
{% trans "This is the title" as the_title %}

<title>{{ the_title }}</title>
<meta name="description" content="{{ the_title }}">

コンテキスチュアルマーカーを付与したい場合は context キーワードが使用できます。

{% trans "May" context "month name" %}

尚、タグやフィルタに文字列リテラルの翻訳を渡したいときは _() シンタックスが使えます。

{% some_tag _("Page not found") value|yesno:_("yes,no") %}

url

特定のビューに対応した絶対パスを生成します。

{% url 'articles:list' %}

第 1 引数には URL パターン名を渡します。 URL パターン名に名前空間を含む場合は、上の例のように : で区切ります。

URL パラメータを渡したい場合は第 2 引数以降で指定できます。

{% url 'some-url-name' v1 v2 %}

URL パラメータは positional 引数でも keyword 引数でも指定することが可能です。

{% url 'some-url-name' arg1=v1 arg2=v2 %}

必須の URL パラメータはすべて渡さないとエラーが出ます。 このエラーがよく起こるのは、引数として渡した変数が存在しない場合です。

{% for article in article_list %}
  {# タイポ `artcle` で存在しない変数を指定した結果エラーが起こる #}
  <a href="{% url "articles:detail" artcle.id %}">{{ article.title }}</a>
{% endfor %}

verbatim

Django テンプレートエンジンによる評価を無効化します。

{% verbatim %}
    {{if dying}}Still alive.{{/if}}
{% endverbatim %}

範囲内の文字列をテンプレートとして評価せずそのまま出力します。 典型的な使いどころは、 Django と似たテンプレートエンジンを持つ JavaScript を出力する場合です。

widthratio

高さに対応した幅を出力します。

<img src="bar.png" alt="Bar"
     height="10" width="{% widthratio this_value max_value max_width %}">

各変数の値が this_value が 175 、 max_value が 200 、 max_width が 100 のとき、この widthratio の出力は 88 になります( 88 = round(175 / 200 * 100) )。

with

範囲内でのみ有効な一時的な変数を定義します。

{% with total=business.employees.count %}
    {{ total }} employee{{ total|pluralize }}
{% endwith %}

複数の変数をまとめて定義することもできます。

{% with alpha=1 beta=2 %}
    ...
{% endwith %}

古いシンタックス {% with business.employeees.count as total %} もまだ使用できます。

テンプレートフィルタ

add

対象の値に引数で渡された値を追加します。

{{ value|add:"2" }}

add フィルタは最初に各値を int に変換して追加しようとします。 それに失敗したらそのまま追加しようとします。 それも失敗した場合は空文字列を返します。

上の例で value の値が 10 のとき、出力は 12 になります。

+ 演算子が使える要素同士であればどのような値にも使えるので、例えば、 values1values2 がともに list であれば次のようなこともできます。

{# values1 と values2 の値を順番に出力する #}
{% for value in values1|add:values2 %}
  <li>{{ value }}</li>
{% endfor %}

addslashes

文字列内の引用符 '" の前にバックスラッシュを追加します。

{{ value|addslashes }}

valueI'm using Django. の場合、出力は I\'m using Django になります。

CSV 内のセルのエスケープ等に有用とされています。

apnumber

1 から 9 までの数字をアルファベット表現に変換します。 1 未満と 10 以上の数字はそのまま返します。

{% load humanize %}
<ul>
  {% for number in numbers %}
    <li>{{ number|apnumber }}</li>
  {% endfor %}
</ul>

例えば上のコードで numbersrange(13) のとき以下のリストに相当する HTML を生成します。

  • 0
  • one
  • two
  • three
  • four
  • five
  • six
  • seven
  • eight
  • nine
  • 10
  • 11
  • 12

公式サイトではこれは「 Associated Press スタイル」( AP 通信のスタイルブックのスタイル?)に従うと説明されています。

尚このタグを利用するには、設定項目 INSTALLED_APPSdjango.contrib.humanize を追加する必要があります。

capfirst

先頭文字を大文字に変換します。 先頭文字がアルファベットではない場合は効果はありません。

{{ value|capfirst }}

center

指定された字数の中で文字列を中央揃えにして出力します。

<pre>
"{{ value|center:"15" }}"
</pre>

上のコードで valueDjango のとき、出力は " Django " になります。

cut

文字列内の特定の文字を除去します。

{{ value|cut:"ん" }}

上のコードで valueにんじん のとき、出力は にじ になります。

除去できる文字の種類は 1 文字だけです。 内部では str.replace() メソッドが使われています。

date

日付オブジェクトを指定されたフォーマットで出力します。

{{ value|date:"Y/m/d (D) H:i:s" }}

上のコードで valuedatetime.datetime(2018, 5, 27, 3, 32, 30) の場合、出力は 2018/05/27 (Sun) 03:32:30 になります。

フォーマット指定には PHP の date() 関数と似たフォーマット指定子が利用できます( PHP からの移行をかんたんにするために意図的に PHP 互換で作られたとのことです)。

以下のいずれかの設定項目で定義されたフォーマットを使うこともできます。

  • DATE_FORMAT
  • DATETIME_FORMAT
  • SHORT_DATE_FORMAT
  • SHORT_DATETIME_FORMAT

例:

投稿日: {% value|date:"DATE_FORMAT" %}

フォーマットが省略されたときは DATE_FORMAT のフォーマットが使用されます。

{{ value|date }}

default

値が falsy (= bool() に渡されたときの戻り値が False )の場合に、引数で指定された文字列を出力します。値が truthy の場合はそのまま出力します。

{{ value|default:"nothing" }}

default_if_none

値が None の場合に引数で指定された文字列を出力します。値が None 以外の場合はそのまま出力します。

{{ value|default_if_none:"nothing" }}

変数が存在しない場合は何も出力しません。

dictsort

各要素が dictlist を引数で指定されたキーでソートします。 順序は昇順です。

{{ value|dictsort:"age" }}

上のコードで value の値が次の list のとき

[
    {'name': 'ポチ', 'age': 3},
    {'name': 'タマ', 'age': 1},
    {'name': 'タロウ', 'age': 10},
]

次の出力になります。

[{'name': 'タマ', 'age': 1}, {'name': 'ポチ', 'age': 3}, {'name': 'タロウ', 'age': 10}]

for タグや with タグと組み合わせて使用すると有用です。

<ul>
  {% for item in d|dictsort:"age" %}
    <li>{{ item.name }}: {{ item.age }}</li>
  {% endfor %}
</ul>

出力のイメージ:

  • タマ: 1
  • ポチ: 3
  • タロウ: 10

ネストされた dict に対してキーを指定することもできます。

{% for book in books|dictsort:"author.age" %}
    * {{ book.title }} ({{ book.author.name }})
{% endfor %}

dictsort は内部で __getitem__ を使用するので、各要素が dictlist だけでなく、各要素が listtuplelist にも使えます。

{{ value|dictsort:0 }}

dictsortreversed

各要素が dictlist を引数で指定されたキーでソートします。 ただし、順序が dictsort とは異なり降順です。

divisibleby

値が指定された引数で割り切れる場合に True を返します。

{{ value|divisibleby:"3" }}

escape

HTML の特殊文字をエスケープします。

変換される文字は以下のとおりです。

変換前 変換後
< &lt;
> &gt;
' &#x27;
" &quot;
& &amp;
{{ value|escape }}

このエスケープ処理はデフォルトで有効になっているため、通常のコンテキストでは効果はありません(エスケープが二重に走ったりはしません)。

内部では django.utils.html.conditional_escape() が使われています。

escape フィルタは autoescape タグで自動エスケープを無効にしたときに選択的にエスケープをしたいときに有用です。

{% autoescape off %}
    {{ title|escape }}
{% endautoescape %}

escapejs

JavaScript の文字列として使われる値をエスケープします。

<script>
var value = "{{ value|escapejs }}";
</script>

上のコードで value が文字列 testing\r\njavascript 'string" <b>escaping</b> のとき、出力は testing\u000D\u000Ajavascript \u0027string\u0022 \u003Cb\u003Eescaping\u003C/b\u003E になります。

文字列の中で使うと HTML シンタックスエラーを防いでくれますが、 JavaScript のテンプレートリテラルといっしょに使うと XSS の危険があるためテンプレートリテラルと併用すべきではありません。 例えば、次のコードで value${alert(100)} という文字列が渡されると ブラウザが alert(100) を実行してしまいます。

<script>
var value = `{{ value|escapejs }}`;
</script>

Python から JavaScript に値を受け渡ししたい場合は後から追加された json_script フィルタを使うと便利です。

filesizeformat

ファイルサイズの数字を人間が読みやすい形に変換します。

{{ value|filesizeformat }}

例:

  • 13 KB
  • 4.1 MB
  • 102 bytes

first

list または tuple の先頭の要素を返します。

{{ value|first }}

先頭の要素が取得できないときは何も出力しません。 内部では value[0] で先頭の要素を取得するので、インデックスアクセスのできない iterator はサポートしていません。

floatformat

指定された桁数で浮動小数点をフォーマットします。

{{ value|floatformat:3 }}

引数には正の整数と負の整数が使えます。 引数が正の数の場合は、小数点以下指定された桁を残してフォーマットします。

value Template Output
34.23234 `{{ value floatformat:3 }}`
34.00000 `{{ value floatformat:3 }}`
34.26000 `{{ value floatformat:3 }}`

引数が負の数の場合は、基本的には正の数の場合と同じですが、値が整数とみなせる場合は小数点以下を出力しません。

value Template Output
34.23234 {{ value floatformat:"-3" }} 34.232
34.00000 {{ value floatformat:"-3" }} 34
34.26000 {{ value floatformat:"-3" }} 34.260

引数を省略することもでき、そのときの挙動は引数が -1 のときの挙動になります。

value Template Output
34.23234 `{{ value floatformat }}`
34.00000 `{{ value floatformat }}`
34.26000 `{{ value floatformat }}`

force_escape

HTML の特殊文字をエスケープします。 処理内容は escape と同じですが、 escape がエスケープ処理が重複して起こらないようにするのに対し、 force_escape はその場でエスケープ処理を必ず行います。

{% autoescape off %}
    {{ body|linebreaks|force_escape }}
{% endautoescape %}

filter タグと組み合わせて使うとタグの出力を強制的にエスケープすることができます。

<pre>
  {% filter force_escape %}
  {% debug %}
  {% endfilter %}
</pre>

内部では django.utils.html.escape() が使われています。

レアケースを除き通常は escape フィルタを使います。

get_current_timezone

現在アクティブなタイムゾーンを返します。

{% load tz %}
{% get_current_timezone as TIME_ZONE %}
{{ TIME_ZONE }}

必ず as を用いて変数に格納する必要があります。

同じ値を取得する別の方法として、コンテキストプロセッサ django.template.context_processors.tz とコンテキスト変数 TIME_ZONE を使う方法もあります。

get_digit

渡された値を int とみなして、引数で指定された桁目の数字を返します。

{{ value|get_digit:"2" }}

上のコードで value50134 の場合、出力は 3 になります。

int とみなせない値には何も処理を加えずそのまま返します。 渡された値の桁数が引数で指定された桁よりも少ない場合は 0 を返します。

intcomma

int (または float )にみなせる値を 3 桁ごとに , を付けた表現に変換します。

{% load humanize %}
{{ value|intcomma }}

例:

変換前 変換後
4500 4,500
4500.2 4,500.2
45000 45,000
450000 450,000
4500000 4,500,000

尚このタグを利用するには、設定項目 INSTALLED_APPSdjango.contrib.humanize を追加する必要があります。

設定項目 USE_L10NUSE_THOUSAND_SEPARATOR が共に True の場合、 intcomma と同様の処理が自動で行われます。

intword

int とみなせる値を人間が読みやすい表現に変換します。

{% load humanize %}
{{ value|intword }}
{% load humanize %}
<ul>
  <li>{{ 10000|intword }}</li>
  <li>{{ 1000000|intword }}</li>
  <li>{{ 10000000000|intword }}</li>
  <li>{{ 10000000000000|intword }}</li>
  <li>{{ 10000000000000000|intword }}</li>
  <li>{{ 10000000000000000000|intword }}</li>
</ul>

上のコードは次のリストに対応する HTML を出力します。

  • 10000
  • 1.0 million
  • 10.0 billion
  • 10.0 trillion
  • 10.0 quadrillion
  • 10.0 quintillion

10^100 ( Googol )までがサポートされているとのことです。

言語を日本語にする場合は使うシーンがあまり無さそうです。

尚このタグを利用するには、設定項目 INSTALLED_APPSdjango.contrib.humanize を追加する必要があります。

iriencode

IRI 文字列を ASCII 文字のみからなる URI にエンコードします。

{{ value|iriencode }}

特定の文字列を URL に含めるときに使用します。

例:

変換前 変換後
?test=1&me=2 ?test=1&amp;me=2
/news/犬/ /news/%E7%8A%AC/
/news/🐶/ /news/%F0%9F%90%B6/

IRI は Internationalized Resource Identifier の、 URI は Universal Resource Identifier の略語です。

参考:

内部では django.utils.encoding.iri_to_uri() が使用されます。

join

list 等の iterable を引数で指定された文字で結合します。 ちょうど Python の str.join() と似た挙動をします。

{{ value|join:' / ' }}

上のコードで value['<a href="/">ホームへ</a>', '<strong>強調</strong>'] の場合の出力は次のとおりです。

&lt;a href="/"&gt;リンク&lt;/a&gt; / &lt;strong&gt;強調&lt;/strong&gt;

iterable の各要素は join の時点でエスケープされます。

json_script

Python オブジェクトを JSON として安全に出力し <script> タグで囲います。 Python から JavaScript に値を渡すときに使用します。

{{ value|json_script:"hello-data" }}

上のコードで value{'hello': 'world'} という dict の場合、次の内容が出力されます。

<script id="hello-data" type="application/json">{"hello": "world"}</script>

引数には <script> タグの id アトリビュートの値を指定します。

XSS 攻撃対策として <>& をエスケープします。

この値は次の形で JavaScript でアクセスできます。

var value = JSON.parse(document.getElementById('hello-data').textContent);

language_bidi

言語コードに対して、言語が右から左に読む言語(アラビア語等)の場合のみ True を返します。

{% load i18n %}
<ul>
<li>en: {{ 'en'|language_bidi }}</li>
<li>ja: {{ 'ja'|language_bidi }}</li>
<li>ar: {{ 'ar'|language_bidi }}</li>
</ul>

上のコードは次のリストに対応する HTML を生成します。

  • en: False
  • ja: False
  • ar: True

language_name

言語コードに対して、英語での言語名を返します。

{% load i18n %}
{{ 'ja'|language_name }}

上のコードは Japanese を出力します。

language_name_local

言語コードに対して、その言語での言語名を返します。

{% load i18n %}
{{ 'ja'|language_name_local }}

上のコードは 日本語 を出力します。

language_name_translated

言語コードに対して、現在アクティブな言語での言語名を返します。

{% load i18n %}
{{ 'ja'|language_name_translated }}

last

list または tuple の末尾の要素を返します。

{{ value|first }}

末尾の要素が取得できないときは何も出力しません。 内部では value[-1] で末尾の要素を取得するので、インデックスアクセスのできない iterator はサポートしていません。

length

iterable な値の要素数を返します。

{{ value|length }}

内部的には len(value) が行われています。 len() が適用できない値に対しては 0 を返します。

length_is

渡された値の長さが引数で指定された数と一致するかどうかをチェックします。

{{ value|length_is:"4" }}

一致する場合は True を、一致しない場合は False を返します。 内部的には len(value) == int(param) のチェックが行われます。 len() が適用できない値に対しては空文字列を返します。

linebreaks

プレーンテキスト内の改行文字を適切な HTML に変換します。 改行 1 つは <br> タグに、連続した改行は <p> タグに変換します。

{{ body|linebreaks }}

上のコードで body が次のように定義されていた場合、

body = """昔々あるところに
おじいさんとおばあさんが
暮らしていました。

ある日おばあさんが川に洗濯に出かけると
大きな桃が流れてきました。
"""

出力は次のとおりになります。

<p>昔々あるところに<br>おじいさんとおばあさんが<br>暮らしていました。</p>

<p>ある日おばあさんが川に洗濯に出かけると<br>大きな桃が流れてきました。<br></p>

linebreaksbr

プレンーテキスト内の改行文字を <br> に変換します。 linebreaks が連続した改行を <p> タグに変換するのに対し、 linebreaksbr はすべての改行を <br> タグに変換します。

{{ body|linebreaksbr }}

上のコードで body が次のように定義されていた場合、

body = """昔々ある村に
浦島太郎という若者がいました。

ある日浦島太郎が海岸を通りかかると
子どもたちが大きなカメをいじめていました。
"""

出力は次のとおりになります。

昔々ある村に<br>浦島太郎という若者がいました。<br><br>ある日浦島太郎が海岸を通りかかると<br>子どもたちが大きなカメをいじめていました。<br>

linenumbers

テキストに行番号を付けます。

{{ body|linenumbers }}

上のコードで body が次のように定義されていた場合、

body = """昔々あるところに
心の優しいおじいさんとおばあさんが住んでいました。
ふたりはシロという名前の犬を飼っていました。
"""

出力は次のとおりになります。

1. 昔々あるところに
2. 心の優しいおじいさんとおばあさんが住んでいました。
3. ふたりはシロという名前の犬を飼っていました。
4.

このままではブラウザで見た場合は改行が失われます。 linenumbers の後に linebreaksbr を付ける等すればきれいに表示されます:

{{ body|linenumbers|linebreaksbr }}

ljust

文字列を引数で指定された幅の中で左寄せします。

"{{ value|ljust:"10" }}"

上のコードで value の値が "Django" のとき、出力は "Django " になります。

localize

文字列をローカラズします。

{% load l10n %}
{{ value|localize }}

設定項目 USE_L10N よりも細かい粒度での制御ができます。 大きなパーツに対してローカライゼーションを制御したい場合には localize タグが便利です。

localtime

日時オブジェクトのタイムゾーンを現在のタイムゾーンに変換します。

{% load tz %}
{{ value|localtime }}

lower

文字列の中の大文字をすべて小文字に変換します。

{{ value|lower }}

上のコードで value の値が "Toy Story 3" のとき、出力は toy story 4 になります。

make_list

値を list 化します。

{{ value|make_list }}

例:

変換前 変換後
"Jumanji" (str) ['J', 'u', 'm', 'a', 'n', 'j', 'i']
527 (int) ['5', '2', '7']

naturalday

{% load humanize %}

尚このタグを利用するには、設定項目 INSTALLED_APPSdjango.contrib.humanize を追加する必要があります。

naturaltime

{% load humanize %}

尚このタグを利用するには、設定項目 INSTALLED_APPSdjango.contrib.humanize を追加する必要があります。

ordinal

{% load humanize %}

尚このタグを利用するには、設定項目 INSTALLED_APPSdjango.contrib.humanize を追加する必要があります。

phone2numeric

英字を含む電話番号を数字表現に変換します。

{{ value|phone2numeric }}

上のコードで value の値が "800-COLLECT" のとき、出力は 800-2655328 になります。

日本語のサイトではほとんど使い途は無さそうです。

pluralize

複数形の接尾語を出力します。 デフォルトは s です。

You have {{ num_messages }} message{{ num_messages|pluralize }}.

上のコードで num_messages が 1 のとき、出力は You have 1 message. になります。 num_messages が 2 のとき、出力は You have 2 messages. になります。

引数で接尾語を s 以外のものに変更することができます。

You have {{ num_walruses }} walrus{{ num_walruses|pluralize:"es" }}.

接尾語の有無だけでカバーできない単語の場合は、単数形と複数形を , でつなげたものを引数に指定すれば OK です。

You have {{ num_cherries }} cherr{{ num_cherries|pluralize:"y,ies" }}.

pprint

変数を見やすい形に出力する pprint.pprint() のラッパーです。

{{ value|pprint }}

厳密に言うと内部では pprint.pprint() ではなく pprint.pformat() が使われています。

random

指定された list の中からランダムに要素をひとつ返します。

{{ value|random }}

上のコードで value['ランボー', 'ランボー 怒りの脱出', 'ランボー 3 怒りのアフガン'] という list だったとき、出力は ランボー 3 怒りのアフガン 等になります。

内部では random.choice() が使われています。

rjust

文字列を引数で指定された幅の中で右寄せします。

"{{ value|rjust:"10" }}"

上のコードで value の値が "Django" のとき、出力は " Django" になります。

safe

値をエスケープ済みの安全な値としてマークし、出力時の HTML エスケープを行いません。

{{ value|safe }}

上のコードで value の値が <a href="/there">here</a> という str だったとき、 a タグのリンクが出力されます。

safe の後ろにフィルタを繋げる場合は注意が必要です。 safe で一度エスケープ済みとしてマークされた文字列はその後のエスケープ処理をパスしてしまうことがあります。

例えば、次のコードで value に上と同じ <a href="/there">here</a> という str を渡したとき、出力はエスケープされずに a タグのリンクが出力されます。

{{ value|safe|escape }}

これは、 escape フィルタに「安全な値としてマークされた値を二重にエスケープしない機能」が備わっているために起こります。

safeseq

iterable なオブジェクトの各要素に safe フィルタを適用します。

{{ value|safeseq|join:", " }}

slice

list のスライスを返します。

{{ value|slice:":2" }}

Python のスライスシンタックス alist[start:stop:step] と同じ形で切り出し方を指定できます。

例えば次のコードは value の要素を逆順に出力します。

{{ value|slice:"-1::-1" }}

slugify

文字列を URL のスラッグに変換します。

{{ value|slugify }}

具体的には次の処理を行います。

  • ユニコードを NFKD に標準化
  • ASCII に変換
  • 英数字と -_ 以外の文字を除去
  • スペースを - に変換
変換前 変換後
Have You Ever Seen the Rain? have-you-ever-seen-the-rain
café latte cafe-latte
富士山 (空文字列)
# context['value'] = 'Have You Ever Seen the Rain?'
context['value'] = 'café latte'

stringformat

フォーマット指定子で指定されたとおりに値をフォーマットします。

{{ value|stringformat:"E" }}

利用できるフォーマット指定子は printf スタイルのフォーマット指定子の先頭の % を除去したものです。

striptags

HTML ( XHTML )タグを除去します。

{{ value|striptags }}

ただし、出力される HTML が安全である保証は無いので、 striptags の後に safe フィルタを付けて使うことのないようにしましょう。 Django 公式ドキュメントでは、確かなストリップ処理を求める場合は bleach ライブラリの clean() 関数を使うことが推奨されています。

time

時刻を表すオブジェクトを引数で指定されたフォーマットの文字列に変換します。

{{ value|time:"H:i" }}

datetime.datetimedatetime.time がサポートされています。

フォーマット指定には date フィルタと同じく PHP の date() 関数と似たフォーマット指定子が利用できます。 また、 TIME_FORMAT と指定すると設定項目 TIME_FORMAT で指定されたフォーマットが使えます。

{{ value|time:"TIME_FORMAT" }}

time フィルタは時刻部分のみをサポートしています。 日付部分も含めたい場合は date フィルタを使ってください。

timesince

指定された日時からの経過時間(差分)を文字列として出力します。

{{ posted_at|timesince:current }}

上のコードで posted_at の値が dateime.datetime(2018, 5, 27, 3, 32, 0)current の値が datetime.datetime(2018, 5, 27, 9, 20, 0) のとき、出力は 5 hours 48 minutes になります。

引数を省略した場合、現在時刻からの差分が出力されます。 最小の単位は「分」です。

内部では django.utils.timesince.timesince() が使われます。

timeuntil

指定された日時までの時間(差分)を文字列として出力します。

{{ sale_start_at|timeuntil:current }}

上のコードで sale_start_at の値が dateime.datetime(2021, 5, 27, 3, 32, 0)current の値が datetime.datetime(2021, 5, 24, 1, 20, 0) のとき、出力は 3 days 2 hours になります。

timesince と同様、引数を省略した場合は現在時刻からの差分が出力されます。 最小の単位は「分」です。

内部では django.utils.timesince.timeuntil() が使われます。

timezone

日時オブジェクトを指定されたタイムゾーンに変換します。

{% load tz %}
{{ value|timezone:"Asia/Tokyo" }}

引数には datetime.tzinfo のサブクラスのインスタンスかタイムゾーンを表す文字列が使えます。

title

文字列の中の各単語の先頭の文字を大文字に、残りの文字を小文字に変換します。

{{ value|title }}

上のコードで value の値が just DO IT のとき、出力は Just Do It になります。

truncatechars

文字列を指定された字数に切り詰めます。

{{ value|truncatechars:7 }}

文字列が指定された字数よりも長い場合は、指定された字数を越える部分が切り落とされて末尾の文字が になります。 日本語の文字も 1 文字として扱われます。

上のコードで value の値が 奥田民生になりたいボーイと出会う男すべて狂わせるガール のとき、出力は 奥田民生にな… になります。

truncatechars_html

文字列を指定された字数に切り詰めます。 HTML が壊れないように、開いたままのタグがあれば末尾で閉じられます。

{{ value|truncatechars_html:10 }}

上のコードで value の値が <strong>シティーハンター THE MOVIE 史上最香のミッション</strong> のとき、出力は <strong>シティーハンター …</strong> になります。 結果の HTML をエスケープせずにそのまま出力したい場合は、その後に safe フィルタ等を繋げる必要があります。

truncatewords

文章の文字列を指定された単語数に切り詰めます。

{{ value|truncatewords:3 }}

上のコードで value の値が I'm Mary Poppins Y'All のとき、出力は I'm Mary Poppins … になります。

日本語の文章に対して使うことは稀です。

truncatewords_html

文章の文字列を指定された単語数に切り詰めます。 HTML が壊れないように、開いたままのタグがあれば末尾で閉じられます。

{{ value|truncatewords_html:4 }}

unlocalize

文字列のローカライズを無効にします。

{% load l10n %}
{{ value|unlocalize }}

設定項目 USE_L10N よりも細かい粒度での制御ができます。

unordered_list

ネストされた list<ul><li> でリスト化します。 ただし、ルートの <ul> は出力されないので、利用時に <ul> で囲う必要があります。

<ul class="favorite-books">
{{ value|unordered_list }}
</ul>

上のコードで value が次のとおりに定義された list のとき、

value = [
    'Awesome Mix vol. 1',
    [
        'Hooked on a Feeling',
        'Go All The Way',
        'Spirit In The Sky',
        "Ain't No Mountain High Enough",
    ],
    'Awesome Mix vol. 2',
    [
        'Mr. Blue Sky',
        'Fox on the Run',
        'Bring It on Home to Me',
    ],
]

次の HTML が出力されます。

<ul class="favorite-books">
    <li>Awesome Mix vol. 1
    <ul>
        <li>Hooked on a Feeling</li>
        <li>Go All The Way</li>
        <li>Spirit In The Sky</li>
        <li>Ain&#x27;t No Mountain High Enough</li>
    </ul>
    </li>
    <li>Awesome Mix vol. 2
    <ul>
        <li>Mr. Blue Sky</li>
        <li>Fox on the Run</li>
        <li>Bring It on Home to Me</li>
    </ul>
    </li>
</ul>

upper

文字列の中の小文字をすべて大文字に変換します。

{{ value|upper }}

上のコードで value の値が "red hot chilli peppers" のとき、出力は RED HOT CHILLI PEPPERS になります。

urlencode

値を URL エンコードします。

{{ value|urlencode }}

上のコードで value の値が "https://www.example.org/foo?a=b&c=d" のとき、出力は https%3A//www.example.org/foo%3Fa%3Db%26c%3Dd になります。

引数で文字を渡すと、その文字はエスケープされません。 引数が渡されたなかったときは / だけがエスケープ対象外となります。

内部では urllib.parse.quote() が使われています。

urlize

プレーンテキスト内の URL とメールアドレスをリンクタグ( <a> )に変換します。

{{ value|urlize }}

例:

変換前 変換後
https://example.com/contact/ <a href="https://example.com/contact/" rel="nofollow">https://example.com/contact/</a>
質問は [email protected] まで 質問は <a href="mailto:[email protected]">[email protected]</a> まで

リンクタグには rel="nofollow" 属性が必ず付けられます。

内部では django.utils.html.urlize() が使われています。 HTML マークアップを含む文字列や ' を含むメールアドレスに対しては期待どおりに動かないので注意してください。

urlizetrunc

プレーンテキスト内の URL とメールアドレスをリンクタグ( <a> )に変換します。

{{ value|urlizetrunc:10 }}

基本的には urlize と同じですが、引数でリンクアンカーの最大文字数を指定できます。

上のコードで value の値が "質問は [email protected] まで" のとき、出力は次のとおりになります。

質問は <a href="mailto:[email protected]">contact@e…</a> まで

utc

日時オブジェクトのタイムゾーンを UTC に変換します。

{% load tz %}
{{ value|utc }}

上のコードで value のタイムゾーンが Asia/Tokyo で時刻が 10:00 のとき、返される日時オブジェクトはタイムゾーンが UTC で時刻が 01:00 になります。

wordcount

単語数を返します。

{{ value|wordcount }}

上のコードで value の値が "Just Read the Instructions" のとき、出力は 4 になります。

wordwrap

英文を指定された文字数で折り返します。

{{ value|wordwrap:5 }}

上のコードで value の値が "Of Course I Still Love You" のとき、出力は次のとおりになります。

Of
Course
I
Still
Love
You

ただし HTML のソース内で改行をしても通常ブラウザで見たときには改行にならないため注意が必要です。 ブラウザで見たときにも改行されるようにするには「 <pre> タグで囲う」「後ろに linebreaksbr フィルタを付ける」等の対応が必要です。

yesno

値が TrueFalseNone かによって異なる文字列を出力します。

{{ value|yesno:"オンです,オフです,Noneです" }}

引数には、値が True のときに出力したい文字列、 False のときに出力したい文字列、 None のときに出力したい文字列を , でつなげたものを渡します。

None のときの文字列はオプションです。 指定されなかった場合は、値が None のときは False のときの文字列が出力されます。

{{ value|yesno:"yeah,no" }}

引数を渡さなかったときは yes,no,maybe (を翻訳したもの)が使われます。

参考

About

(Japanese) 🎷 Django テンプレートタグまとめ: ウェブアプリケーションフレームワーク Django のコアが提供するテンプレートタグ・テンプレートフィルタの一覧です。

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published