【Trainer's Recipe】Pythonのフレームワークのflaskを触ってみた。 このEntryは、G's ACADEMY TOKYOのトレーナー/チューターによる投稿記事です。 授業の中で出たちょっとした質問や疑問、トレーナーが関心のある新技術等を脈絡なく綴っていきます。 ![python_flask.png](https://qiita-image-store.s3.amazonaws.com/0/104065/0eb2bb6e-d1ff-a538-6b2f-46ec80773111.png) #pythonのフレームワークのflaskを触ってみた。# ジーズアカデミースタッフの栗林です。 最近ジーズアカデミー内でpythonが流行っているので、自分も触ってみたくなったのでソフトタッチで触ってみました。 今回はFlaskというフレームワークを触ってみたいと思います。 Flask(フラスク)は、プログラミング言語Python用の、軽量なウェブアプリケーションフレームワークです。標準で提供する機能を最小限に保っているため、自身を「マイクロフレームワーク」と呼ばれているとのこと。 参考にしたリンク http://a2c.bitbucket.org/flask/quickstart.html#id2 上記リンクの最小規模のアプリケーション例というタイトルに惹かれて、チャレンジしてみました。 自分のPCでしか試していないので手順通りに行っても動かない可能性もあります。その際はリンク先ページをご参考ください。 早速チャレンジしてみましょう。(Macで行った手順しか書いていません。windowsの方はゴメンナサイ。。。) Pythonのバージョンは以下の通りです。 Python 3.5.2 まず環境を構築しましょう。 ## 環境構築 ターミナルにて以下のコマンドを入力します。(頭にsudoが必要かも・・・) ``` $ easy_install virtualenv ``` こちらでもいいらしい。。。(頭にsudoが必要かも・・・) ``` $ pip3 install virtualenv ``` プロジェクトフォルダー myproject 内に env という環境を作ります。 ``` $ mkdir myproject $ cd myproject $ virtualenv env ``` この環境をこの環境を使用するようアクティブ化するとの事。下記コマンドを入力。 ``` $ . env/bin/activate ``` ## Flaskのインストール Flaskをインストールします。 ``` $ easy_install Flask ``` これでインストールできたのか。。 ## hello worldに挑戦 早速、hello worldをやってみます。 まずはhello.pyファイルを作成します。 ``` /myproject /hello.py ``` hello.pyファイルを作成し、以下のコードを記載します。 ```python:hello.py from flask import Flask app = Flask(__name__) @app.route('/') def hello_world(): return "Hello World!だよ" if __name__ == '__main__': app.run(debug=True) ``` 上記を入力したら、ターミナルにてhello.pyファイルが格納されている場所にて以下のコマンドを入力します。 ``` $ python3 hello.py * Running on http://127.0.0.1:5000/ ``` これでサーバーが立ち上がっている模様。 ブラウザから http://127.0.0.1:5000/ へアクセスしてみると、 ![スクリーンショット 2016-07-29 2.53.43.png](https://qiita-image-store.s3.amazonaws.com/0/104065/5d368d07-8d73-284e-cbf2-80e958975388.png) おおー!Hello World成功! たったこれだけでできるなんて超カンタン。素晴らしい。 ## htmlテンプレートを返す 今度はhtmlファイルを返すようにしてみたいので、チャレンジしてみます。 Flaskはテンプレート templates フォルダから探すとのことなので、templatesフォルダを作成し、テンプレートとしてhello.htmlを作成。 ``` /myproject /hello.py /templates /hello.html ``` hello.htmlに以下のコードを記述 ```templates/hello.html Hello from Flask {% if name %}

{{ name }}さん!テンプレートからのHello Worldだよ!

{% else %}

テンプレートからのHello Worldだよ!

{% endif %} ``` これでいいのかな? 今度はブラウザから http://127.0.0.1:5000/hello へアクセスしてみると、 ![スクリーンショット 2016-07-29 12.34.50.png](https://qiita-image-store.s3.amazonaws.com/0/104065/da0b82a0-e823-bfe2-fc6c-ede941ffd975.png) おお!表示された! 今度はブラウザから http://127.0.0.1:5000/hello/栗林 へアクセスしてみると、 ![スクリーンショット 2016-07-29 12.36.24.png](https://qiita-image-store.s3.amazonaws.com/0/104065/0859b177-4d6b-9173-b625-fb7a219e9a28.png) 「栗林」の文字を反映できた! ## スタティックファイル cssやjavascript、画像についても反映させてみます。 ### cssファイル まずはcssから。 static という名前のフォルダーをパッケージ内かモジュールの隣に作っておくだけで、 /static がアプリケーション上で呼び出せるとのこと。 フォルダ構成を以下のようにしてみた。 ``` /myproject /hello.py /templates /hello.html /static /css /style.css ``` style.cssファイルに以下のコードを記述。 ```static/css/style.css @charset 'utf-8'; body { background: #0fa; } ``` 適当に背景色を変えてみよう。 cssファイルを読み込むように、hello.htmlファイルも以下のように変更。 ```templates/hello.html G's academy Trainer's Recipe Hello from Flask {% if name %}

{{ name }}さん!テンプレートからのHello Worldだよ!

{% else %}

テンプレートからのHello Worldだよ!

{% endif %} ``` ブラウザから http://127.0.0.1:5000/hello/栗林 へアクセスしてみると、 ![スクリーンショット 2016-07-29 12.48.51.png](https://qiita-image-store.s3.amazonaws.com/0/104065/f372b99b-439a-ac8b-5c2e-1e1fc452ce31.png) おお〜!反映されてる。 ### JavaScriptを記述 javascriptも書いてみよう。 staticフォルダ内にjsフォルダを作成し、main.jsファイルを格納。 ``` /myproject /hello.py /templates /hello.html /static /css /style.css /js /main.js ``` main.jsファイル内を以下のように記述。 ```static/js/main.js (function(){ 'use strict'; alert('アラートだよ〜。'); })(); ``` hello.htmlファイルにjavascript読み込みのscriptタグを追記。 ```templates/hello.html G's academy Trainer's Recipe Hello from Flask {% if name %}

{{ name }}さん!テンプレートからのHello Worldだよ!

{% else %}

テンプレートからのHello Worldだよ!

{% endif %} ``` ブラウザをリロードすると、、、 ![スクリーンショット 2016-07-29 12.56.35.png](https://qiita-image-store.s3.amazonaws.com/0/104065/39577849-b86f-6218-b2ad-e4eea3c3759c.png) アラート表示に成功! ### 画像を表示 画像も表示させたいのでやってみよう。 staticフォルダ内にimagesフォルダを作成し、ちょっと前に描いたスケッチの画像をpic01.pngファイルを格納。 ``` /myproject /hello.py /templates /hello.html /static /css /style.css /js /main.js /images /pic01.png ``` hello.htmlファイルを以下のように修正。 ```templates/hello.html G's academy Trainer's Recipe Hello from Flask {% if name %}

{{ name }}さん!テンプレートからのHello Worldだよ!

{% else %}

テンプレートからのHello Worldだよ!

{% endif %}

pic01

``` ブラウザをリロードすると、、、 ![スクリーンショット 2016-07-29 13.10.08.png](https://qiita-image-store.s3.amazonaws.com/0/104065/494a7b0e-ef5b-871d-3773-0b562de746b0.png) おお〜!素晴らしい! 今回はソフトタッチにPythonのフレームワークのFlaskを触ってみました。 かなりお手軽なので、素晴らしいと感じました。 Ruby on Railsはちょこっと触ったことがあるのですが、Railsと比較すると、非常にシンプルで、ブラックボックス的に感じる部分が少なくて良いですね。 Pythonには、Flaskの他にも、Django, Pyramid, Bottle, Falconなど、いろいろあるようなので、気になる方はいろんなフレームワークを触ってみてください。 以上、G's ACADEMY TOKYOスタッフ栗林によるTrainer's Recipeでした。