質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

4310閲覧

jinja2でSyntaxエラーが発生する

B-Hirosuke

総合スコア22

Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2018/12/29 02:23

編集2018/12/29 08:51

状況

現在、FlaskでWebアプリケーションを作成しています。
index.html を読み込もう(ブラウザ上で表示しよう)とした時にエラーが発生します。

実行しているコード(一部)

python

1"""app.py""" 2@app.route("/") 3def index(): 4 return render_template("index.html", system_info=get_system_info())

HTML

1<!-- index.html --> 2{% block page_content %} 3<div class="container" id="main"> 4 <div class="row"> 5 <div class="col-md-9"> 6 {% include 'index_partial/datasets.html' %} 7 </div> 8 <div class="col-md-3"> 9 {% include 'common/resource_info.html' %} 10 </div> 11 </div> 12 </div> 13{% endblock %}

HTML

1<!-- index_partial/datasets.html --> 2<div class="subtitle"> 3 <h2>Dataset</h2> 4 <div class="button_div" right> 5 <a href="#"> 6 <button class="btn btn-cyber" data-toggle="model" data-target="#upload_model"> 7 <span class="glyphicon glyphicon-plus"></span>New 8 </button> 9 </a> 10 </div> 11</div> 12<div class="datasets"> 13 <div class="datasets_row"> 14 {% for dataset in datasets %} 15 <div class="dataset image" id="dataset_{{ dataset.id }}" data-id="{{ dataset.id}}"> 16 <h3>{{ dataset.name }}</h3> 17 <span class="desc">Total {{ dataset.file_num }} Images</span> 18 {% for img in dataset.thumbnails %} 19 <img src="{{img}}" class="img-responsive img-rounded thumbnail-30"> 20 {% endfor %} 21 </div> 22 {% endfor %} 23 </div> 24 {% if dataset_count > 3 %} 25 <button class="btn btn-cyber btn-block" id="dataset_more" data-offset="3">more</button> 26 {% endif %} 27</div>

エラーメッセージの内容

jinja2.exceptions.TemplateSyntaxError jinja2.exceptions.TemplateSyntaxError: unexpected '%'

上記のように、「% が変なところに付いている」というエラーだと思います。
しかし、エラーの元を探しても間違っていそうな場所を見つけられず、質問しました。

試したこと

index.html{% include 'index_partial/datasets.html' %}を消してみると、エラーが消えたので
問題はここにあると思います。

別の質問を立ち上げました

よろしくお願いします

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

endforifendifの前後は{{%ではなく{%では?
参考:jinja2入門 その1

include文自体には問題はないように見えます。

検証

以下コードにて、当方環境では構文エラー発生せず動作しました。
提示コードではjinja2.exceptions.UndefinedError: 'dataset_count' is undefined発生したため定義しています。
また、index.htmlでは{% include 'common/resource_info.html' %}はコメントアウトしています。
index_partial/datasets.htmlは提示コードのままです。

Python

1from flask import Flask, render_template 2 3app = Flask(__name__) 4 5def get_system_info(): 6 return 7 8@app.route('/') 9def index(): 10 return render_template("index.html", system_info=get_system_info(), dataset_count=0) 11 12if __name__ == '__main__': 13 app.run(debug=True)

Python

1<!-- index.html --> 2{% block page_content %} 3<div class="container" id="main"> 4 <div class="row"> 5 <div class="col-md-9"> 6 {% include 'index_partial/datasets.html' %} 7 </div> 8 <div class="col-md-3"> 9 {# {% include 'common/resource_info.html' %} #} 10 </div> 11 </div> 12 </div> 13{% endblock %}

イメージ説明

投稿2018/12/29 02:30

編集2018/12/29 07:48
can110

総合スコア38266

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

B-Hirosuke

2018/12/29 02:38

確かにそうですね。 `{{% endfor %}}` と間違えて書いていました。 しかし、まだ同じエラーが発生してしまいます。
can110

2018/12/29 07:49 編集

実際に動作させてみましたが、正常?に描画されました。
B-Hirosuke

2018/12/29 08:15

そうですか。 もしかしたら、HTMLじゃなく別の部分に問題があるのかもしれないですね。 色々試していると全く別のエラーが発生するようになりました。 一度、別の現在起こっているエラーを別の質問として投稿します。 よろしくお願いします。
can110

2018/12/29 08:16

Flaskほとんど触ったことないので、お役に立てるかどうか分かりませんが…
guest

0

自己解決

解決方法

ディレクトリ構成

applicationdir ----- src ----------- templates
| |-------- app.py
| |--------- ...
|
|----------------------- database.db

エラーが発生している時の場合

terminal

1$ cd src 2$ python app.py

のようにファイルを移動してapp.pyを実行していました.

terminal

1$ python src/app.py

のように実行すると正常に動作しました。

エラーの理由

本来は、「srcディレクトリに移動せずにデータベースを参照する」というような設定をしていたのですが、app.pyが置かれているディレクトリでプログラムを実行していました。
そのため、データベースを参照することができず、データベースエラーが発生してました。
その影響でHTMLファイルにも影響が出ていたのだと思います。

最後に

ご助言をしていただいた can100様 本当にありがとうございました。

投稿2018/12/29 13:23

B-Hirosuke

総合スコア22

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問