回答:
jsonify
JSONに渡すデータをシリアル化します。自分でデータをシリアル化する場合はjsonify
、status=200
およびを使用して応答を作成することにより、何を行うかを指定しmimetype='application/json'
ます。
from flask import json
@app.route('/summary')
def summary():
data = make_summary()
response = app.response_class(
response=json.dumps(data),
status=200,
mimetype='application/json'
)
return response
キーワード引数をに渡すflask.jsonify
と、JSONオブジェクトとして出力されます。
@app.route('/_get_current_user')
def get_current_user():
return jsonify(
username=g.user.username,
email=g.user.email,
id=g.user.id
)
{
"username": "admin",
"email": "admin@localhost",
"id": 42
}
すでに辞書がある場合は、直接として渡すことができますjsonify(d)
。
jsonify
なんらかの理由で使用したくない場合は、手動で実行できます。呼び出しflask.json.dumps
てJSONデータを作成し、application/json
コンテンツタイプを含む応答を返します。
from flask import json
@app.route('/summary')
def summary():
data = make_summary()
response = app.response_class(
response=json.dumps(data),
mimetype='application/json'
)
return response
flask.json
組み込みjson
モジュールとは異なります。simplejson
可能な場合はより高速なモジュールを使用し、Flaskアプリとのさまざまな統合を可能にします。
ユーザーがアップロードしたファイルを分析する場合、Flask クイックスタートはユーザーからファイルを取得してアクセスする方法を示します。からファイルを取得request.files
して、サマリー関数に渡します。
from flask import request, jsonify
from werkzeug import secure_filename
@app.route('/summary', methods=['GET', 'POST'])
def summary():
if request.method == 'POST':
csv = request.files['data']
return jsonify(
summary=make_summary(csv),
csv_name=secure_filename(csv.filename)
)
return render_template('submit_data.html')
の'data'
キーをrequest.files
、HTMLフォームに入力されたファイルの名前に置き換えます。
バージョン1.1.0 Flask以降、ビューがdictを返す場合、JSON応答に変換されます。
@app.route("/users", methods=['GET'])
def get_user():
return {
"user": "John Doe",
}
デコレータを使用しての結果を返しjsonfiy
ます。ビューに複数のリターンがある場合、より読みやすいと思います。これはのようなタプルを返すことをサポートしていませんcontent, status
が、app.errorhandler
代わりにエラーステータスを返すことを処理しています。
import functools
from flask import jsonify
def return_json(f):
@functools.wraps(f)
def inner(**kwargs):
return jsonify(f(**kwargs))
return inner
@app.route('/test/<arg>')
@return_json
def test(arg):
if arg == 'list':
return [1, 2, 3]
elif arg == 'dict':
return {'a': 1, 'b': 2}
elif arg == 'bool':
return True
return 'none of them'
Flask 0.11より前のバージョンでjsonfiy
は、配列を直接返すことはできませんでした。代わりに、リストをキーワード引数として渡します。
@app.route('/get_records')
def get_records():
results = [
{
"rec_create_date": "12 Jun 2016",
"rec_dietary_info": "nothing",
"rec_dob": "01 Apr 1988",
"rec_first_name": "New",
"rec_last_name": "Guy",
},
{
"rec_create_date": "1 Apr 2016",
"rec_dietary_info": "Nut allergy",
"rec_dob": "01 Feb 1988",
"rec_first_name": "Old",
"rec_last_name": "Guy",
},
]
return jsonify(results=list)
Flask 1.1では、辞書を返すと、自動的にJSONに変換されます。したがってmake_summary()
、辞書を返す場合は、
from flask import Flask
app = Flask(__name__)
@app.route('/summary')
def summary():
d = make_summary()
return d
ステータスコードを含めることを要求するSOは、このコードの複製としてクローズされました。したがって、その質問にも答えるために、フォームのタプルを返すことでステータスコードを含めることができます(dict, int)
。dict
JSONに変換され、int
HTTPステータスコードになります。入力がない場合、ステータスはデフォルトの200になります。したがって、上記の例ではコードは200になります。以下の例では、201に変更されます。
from flask import Flask
app = Flask(__name__)
@app.route('/summary')
def summary():
d = make_summary()
return d, 201 # 200 is the default
ステータスコードを確認するには、
curl --request GET "http://127.0.0.1:5000/summary" -w "\ncode: %{http_code}\n\n"
その辞書の場合、フラスコは直接それを返すことができます(バージョン1.0.2)
def summary():
d = make_summary()
return d, 200
"" " Flaskクラスベースビュー " ""の使用
from flask import Flask, request, jsonify
from flask.views import MethodView
app = Flask(**__name__**)
app.add_url_rule('/summary/', view_func=Summary.as_view('summary'))
class Summary(MethodView):
def __init__(self):
self.response = dict()
def get(self):
self.response['summary'] = make_summary() # make_summary is a method to calculate the summary.
return jsonify(self.response)
フラスコ1.1.x
現在、Flaskサポートリクエストはjsonで直接返され、jsonifyは不要になりました
@app.route("/")
def index():
return {
"api_stuff": "values",
}
に相当
@app.route("/")
def index():
return jsonify({
"api_stuff": "values",
})
詳細については、こちらをご覧くださいhttps://medium.com/octopus-wealth/returning-json-from-flask-cf4ce6fe9aebおよびhttps://github.com/pallets/flask/pull/3111