Flaskのrender_templateの使い方解説
2024年12月3日
data:image/s3,"s3://crabby-images/783fd/783fd061a63b8f2970edcbc1714690687a69ebb1" alt=""
こんにちは!
今回の記事では、Flaskのrender_templateの使い方について解説します。
render_templateとは、Flaskの標準的な関数で、HTMLテンプレートファイルを動的に生成し、ユーザーに返す役割を担っています。
簡単なWebページから、複雑なアプリケーションまで、どのようなアプリを作成するにしてもrender_templateを使うことになるでしょう。
そこで、今回はrender_templateのさまざまな使い方について詳しく解説します。
render_templateの基本的な使い方
まずは、render_templateの基本的な使い方について解説します。
Flaskのインストール
初めにFlaskの準備をします。以下のコマンドを実行して、Flaskをインストールしましょう。
pip install flask
Flaskのインストール方法についてはこちらの記事で詳しく解説しています。
【関連】Flaskのインストール方法とは?Flaskを使ってみよう
今回のディレクトリ構造
今回は簡単なflaskのアプリを作成して、render_templateの使い方を解説します。
以下のような構造のアプリを作成します。
flask_app/
│
├── app.py # Flaskアプリのメインファイル
├── templates/ # HTMLテンプレートを格納するディレクトリ
│ ├── index.html # ホームページのテンプレート
│ └── about.html # 他のページのテンプレート
Flaskのメインファイルである、app.pyとtemplatesディレクトリにHTMLテンプレートを作成します。
app.pyへrender_templateの記述
続いて、app.pyへrender_templateの記述をします。以下のように記述します。
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/')
def home():
return render_template('index.html')
if __name__ == '__main__':
app.run(debug=True)
上記では、Webページの/へアクセスすると、templatesディレクトリのindex.htmlを返すようになります。
templates/index.htmlを以下のように記述します。
<h1>Hello World!</h1>
続いて、Pythonを起動します。
python app.py
Webブラウザから、http://127.0.0.1:5000/へアクセスすると、index.htmlに記述した「Hello World!」が表示されます。
このように、render_templateはどのテンプレートファイルをユーザーに返すのかを指定します。
【関連】Jinja2とは何か?Pythonのテンプレートエンジンについて解説
render_templateの書式
render_templateは以下のように記述します。
render_template('[テンプレートファイル]', key1=value1, key2=value2)
テンプレートファイルの部分は、templatesディレクトリに格納されているテンプレートファイル名を記述します。
次に、キーワード引数を指定します。HTMLテンプレートに渡す変数を [キー] = [値]の形式で指定します。
具体例
例えば、以下のように、 [キー] = [値]を指定して、テンプレートで使用することができます。
@app.route('/')
def hello():
return render_template('hello.html', name="Alice", age=30)
テンプレート側では、{{ }}を使って、渡された変数を表示します。
<!DOCTYPE html>
<html>
<head>
<title>Hello Page</title>
</head>
<body>
<h1>Hello, {{ name }}!</h1>
<p>You are {{ age }} years old.</p>
</body>
</html>
動的な値を渡す
動的な値を渡すことも可能です。
以下のように、usernameが変わる場合に便利です。以下では、値の部分に変数のusernameを指定しています。
@app.route('/user/<username>')
def user_profile(username):
return render_template('profile.html', username=username)
テンプレート側では、以下のように指定します。
<h1>Welcome, {{ username }}!</h1>
http://localhost:5000/user/John にアクセスすると以下のように表示されます。
Welcome, John!
テンプレートディレクトリを変更する場合
render_templateはデフォルトで、templatesディレクトリ配下にあるテンプレートファイルを指定します。
もし、templatesディレクトリ以外に保存する場合は、以下のように設定します。
app = Flask(__name__, template_folder='my_templates')
上記のように、Flaskオブジェクトを作成する際にtemplate_folderを指定します。
まとめ
Flaskのrender_templateは、HTMLテンプレートを動的に生成してWebアプリケーションを構築する上で欠かせない機能です。
本記事では、基本的な使い方から、動的な値の渡し方、テンプレートディレクトリの変更方法まで幅広く解説しました。
これを理解することで、ユーザーごとに異なるコンテンツを提供する柔軟なWebアプリケーションを作成できるようになります。特に、テンプレートエンジンJinja2と連携して変数やロジックをテンプレート内で活用することで、コードの再利用性が向上し、開発効率を高めることが可能です。
Flaskのシンプルさを活かしつつ、render_templateを効果的に活用して、より魅力的なWebアプリケーションを構築してください。
ここまでお読みいただきありがとうございました!
Pythonの基礎から応用まで学べる
Python WebAcademy
Python WebAcademyでは、Pythonの基礎からアーキテクチャなどの応用的な内容まで幅広く学べます。また、ブラウザ上で直接Pythonコードを試すことができ、実践的なスキルを身につけることが可能です。
data:image/s3,"s3://crabby-images/8e3a4/8e3a4d048eca8f6f3ce0f70ab201beb7e0a1b657" alt=""
インフラの学習はInfraAcademy
data:image/s3,"s3://crabby-images/acfa3/acfa3b52531ef6d526e6b7d127fe1b27cca3a80d" alt=""
おすすめの記事
data:image/s3,"s3://crabby-images/2740a/2740a408720760a010984768d7541e25e5ac268b" alt=""
data:image/s3,"s3://crabby-images/de002/de002e836bdfa8e3b7b47d6801e7ab9a37da34f0" alt=""
data:image/s3,"s3://crabby-images/4f11d/4f11dea0118257095fa1f3ca967bd24a2de3e403" alt=""
data:image/s3,"s3://crabby-images/2740a/2740a408720760a010984768d7541e25e5ac268b" alt=""
data:image/s3,"s3://crabby-images/4b2f6/4b2f6092c574a1bbf351202ae09625a0245ecc82" alt=""
data:image/s3,"s3://crabby-images/55985/55985afeeab0ab7658a23115d87862c6a864e472" alt=""
data:image/s3,"s3://crabby-images/602b3/602b34b15d619197949cb8fd6e3b96dcb3a9b949" alt=""
data:image/s3,"s3://crabby-images/24249/24249bb4bb6f36c71a9d6040875a08536d8fdcc9" alt=""
data:image/s3,"s3://crabby-images/d9869/d9869882df86b12677f617b387e5ac19ffee1e6b" alt=""
data:image/s3,"s3://crabby-images/d5eb1/d5eb1050a3fc3c2f59a1a86b829c87a3808b3247" alt=""