2013-06-04 52 views
8

我從MongoDB數據庫使用燒瓶中,有下面的代碼創建一個API:瓶顯示的Json在一個整潔的方式

app.route('/<major>/') 
def major_res(major): 
    course_list = list(client.db.course_col.find({"major" : (major.encode("utf8",  "ignore").upper())})) 
    return json.dumps(course_list, sort_keys=True, indent=4, default=json_util.default) 

當與CSCI主要收益稱爲:

[{「課程」:「CSCI052」,「說明」:「計算機科學的基礎函數式編程,程序和數據抽象,遞歸和解決問題提供堅實的基礎應用到計算機科學的重要領域,包括算法和複雜性。 ,計算機體系結構和組織,編程語言,有限自動機和計算機吳春明。本課程作爲HM 60在任何一個克萊蒙特學院對高年級的計算機科學課程的先決條件相同的作用。先決條件:51 「 」導師「: 」牛,埃弗裏特大號,,小「, 」名「:」 計算機科學」, 「數字基礎」:52, 「學校」: 「PO」}]

如何退還本字典,使每個鍵和值都在自己的行

+0

對於這種使用''json.dimps'參數indent'一個例子,但你已經擁有它。這不是縮小JSON,因爲在逗號和':'後面有空格。那麼你如何得到這個輸出(在瀏覽器中,日誌/打印,wget)呢?可能你需要使用'return Response(,mimetype ='application/json')'或'flask.jsonofy'和'indent'參數。 – tbicr

回答

13

瓶提供jsonify()的方便:

app.route('/<major>/') 
def major_res(major): 
    course_list = list(client.db.course_col.find({"major": major.encode('utf8', 'ignore').upper() })) 
    return flask.jsonify(**course_list) 

這將返回的jsonify的kwargs作爲一個很好的格式化的JSON響應,不像你的代碼,將派遣適當的Content-Type頭:application/json

但是,採取什麼樣的文檔說這個注:

此功能的反應會,如果它不與X-Requested-With: XMLHttpRequest要求,除非JSONIFY_PRETTYPRINT_REGULAR配置參數被設置爲false,以簡化調試美化打印。

這意味着Ajax響應總會接收非prettyprinted JSON(因爲同源策略,使得它不可能取消設置X-Requested-With)。但我想這不會是太大的問題,因爲JSON的JS食用量不宜需要格式化(這是通過電線發送只是額外的數據)。

如果你想仍然使用json.dumps()(非美化打印的),你可以通過返回flask.Response發送正確的MIME類型,但是,你應該考慮the security implications of this

app.route('/<major>/') 
def major_res(major): 
    course_list = list(client.db.course_col.find({"major": major.encode('utf8', 'ignore').upper() })) 
    return flask.Response(response=json.dumps(course_list), status=200, mimetype='application/json') 

欲瞭解更多的差異:

+0

截至Flask 0.13「X-Requested-With」標題被忽略,只有在調試模式下才會強制打印(如果未設置JSONIFY_PRETTYPRINT_REGULAR),請更新答案。 –

0

如果由於某種原因,你需要爲忽略flask.jsonify(添加例如自定義編碼器),你可以用它實現提到的安全修補程序@phpmycoder下面的方法做:

from json import dumps 
from flask import make_response 

def jsonify(status=200, indent=4, sort_keys=True, **kwargs): 
    response = make_response(dumps(dict(**kwargs), indent=indent, sort_keys=sort_keys)) 
    response.headers['Content-Type'] = 'application/json; charset=utf-8' 
    response.headers['mimetype'] = 'application/json' 
    response.status_code = status 
    return response 

app.route('/<major>/') 
def major_res(major): 
course = client.db.course_col.find({"major": (major.encode("utf8", "ignore").upper())}) 
return jsonify(**course) 

app.route('/test/') 
def test(): 
return jsonify(indent=2, sort_keys=False, result="This is just a test") 

響應:

{ 
    "course": "CSCI052", 
    "description": "Fundamentals of Computer Science. A solid foundation in functional programming, procedural and data abstraction, recursion and problem-solving. Applications to key areas of computer science, including algorithms and complexity, computer architecture and organization, programming languages, finite automata and computability. This course serves the same role as HM 60 as a prerequisite for upper-division computer science courses at any of the Claremont Colleges. Prerequisite: 51.", 
    "instructor": "Bull, Everett L.,, Jr.", 
    "name": " Fundamentals of Computer Science", 
    "number": 52, 
    "school": "PO" 
} 

見我other answer使用自定義JSON編碼器

+0

由於只返回一門課程,因此不需要列表。如果你有另一條路線返回多個課程,你可以這樣做: 'courses = query.that.returns.list' and'return jsonify(courses = courses)'' – reubano

相關問題