Flask 返回 Json

一、Flask 返回 Json 科学计数法 在 Flask 中,我们可以通过 jsonify 方法返回 Json 数据。对于数字类型的数据,在传输过程中会出现科学计数法的情况。下面我们来看一个例子:

from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/')

def index():

data = {

"large_number": 12345678901234567890

}

return jsonify(data)

if __name__ == '__main__':

app.run()

这时候,我们访问到网页上的数据会出现:

{

"large_number": 1.2345678901234568e+19

}

这种情况下,我们可以使用 simplejson 库中的 dumps 转换。修改上述代码如下:

from flask import Flask, Response

import simplejson as json

app = Flask(__name__)

@app.route('/')

def index():

data = {

"large_number": 12345678901234567890

}

return Response(json.dumps(data), mimetype='application/json')

if __name__ == '__main__':

app.run()

这时候,我们访问到网页上的数据会正常显示:

{

"large_number": 12345678901234567890

}

二、Flask 返回 Json 文件 我们可以在 Flask 中生成 Json 格式的文件,并且可以直接将该文件返回给前端。下面是一个实例:

from flask import Flask, jsonify

import json

app = Flask(__name__)

@app.route('/file')

def file():

data = {

"name": "John",

"age": 28,

"city": "New York"

}

with open('data.json', 'w') as f:

json.dump(data, f)

return app.send_static_file('data.json')

if __name__ == '__main__':

app.run(debug=True)

在本例中,我们使用 json.dump 将数据写入到 data.json 文件中,并通过 Flask 的 send_static_file 方法返回该 Json 文件的内容。

三、Flask 返回 Html 在 Flask 中,我们可以通过 render_template 方法来返回 HTML 页面。下面是一个实例:

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/index')

def index():

return render_template('index.html')

if __name__ == '__main__':

app.run()

在本例中,我们在 Flask 应用目录下创建了一个名为 index.html 的文件,然后在返回时使用了 render_template 方法。

四、Flask 返回 Json 格式列表 在 Flask 中,实现返回一个 Json 格式的列表,我们可以将所有项都存入一个 Python 的列表中,然后使用 jsonify 方法返回这个列表。下面是一个例子:

from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/list')

def index():

data = [

{

"name": "John",

"age": 28,

"city": "New York"

},

{

"name": "Jane",

"age": 26,

"city": "San Francisco"

},

{

"name": "Bill",

"age": 35,

"city": "Los Angeles"

}

]

return jsonify(data)

if __name__ == '__main__':

app.run(debug=True)

在这个例子中,我们将所有数据都存入了一个列表中,并使用了 jsonify 方法将整个列表作为 Json 格式返回。

五、Flask 返回格式 在 Flask 中,我们可以通过 Response 对象来重新定义返回的格式。下面我们来看一个例子,将返回格式定义为 XML:

from flask import Flask, Response

app = Flask(__name__)

@app.route('/')

def index():

data = '''

John

28

New York

'''

return Response(data, mimetype='text/xml')

if __name__ == '__main__':

app.run(debug=True)

在本例中,我们将数据定义为 XML 格式,并通过 Response 对象将其返回给前端。在 Response 对象中,我们可以自定义 mimetype 来定义返回结果的格式。

六、Flask 返回 Json 数据到前端 在 Flask 中,我们可以通过 Json 数据与前端进行交互。下面是一个例子:

from flask import Flask, jsonify, render_template, request

app = Flask(__name__)

@app.route('/')

def index():

return render_template('index.html')

@app.route('/api')

def api():

keyword = request.args.get('keyword')

result = [

{"name": "John", "age": 28},

{"name": "Jane", "age": 26},

{"name": "Bill", "age": 35}

]

if keyword:

result = [x for x in result if keyword in x['name']]

return jsonify(result)

if __name__ == '__main__':

app.run(debug=True)

在这个例子中,我们在 Flask 中定义了一个名为 api() 的方法,并通过 render_template 方法将前端页面提供给用户。在前端页面中,我们定义了一个名为 search 的文本框,并使用 jQuery 技术对该文本框进行绑定。当用户在文本框中输入关键字时,会自动执行 Ajax 请求,调用 api() 方法获取数据。

七、Flask 返回 Jsonify 重新渲染页面 在 Flask 中,我们可以通过 jsonify 方法重新渲染页面。下面是一个例子:

from flask import Flask, jsonify, render_template

app = Flask(__name__)

@app.route('/posts')

def posts():

posts = [

{"id": 1, "title": "First post", "content": "Hello world!"},

{"id": 2, "title": "Second post", "content": "Flask is awesome!"},

{"id": 3, "title": "Third post", "content": "Coding is fun!"}

]

return render_template('posts.html', posts=posts)

@app.route('/like/')

def like(post_id):

posts = [

{"id": 1, "title": "First post", "content": "Hello world!", "likes": 0},

{"id": 2, "title": "Second post", "content": "Flask is awesome!", "likes": 0},

{"id": 3, "title": "Third post", "content": "Coding is fun!", "likes": 0}

]

for post in posts:

if post['id'] == post_id:

post['likes'] += 1

return jsonify({'likes': posts[post_id-1]['likes']})

if __name__ == '__main__':

app.run(debug=True)

在这个例子中,当用户点击喜欢时,会调用 like() 方法,返回 Json 数据。我们在前端页面中使用 jQuery 对数据进行绑定,并重新渲染页面。

八、Flask 返回文件 在 Flask 中,我们可以通过 send_file 方法返回文件。下面是一个例子:

from flask import Flask, send_file

app = Flask(__name__)

@app.route('/download')

def download():

filename = 'data.txt'

return send_file(filename, as_attachment=True)

if __name__ == '__main__':

app.run(debug=True)

在本例中,我们通过 send_file 方法将一个文件返回给前端用户。

九、Flask 返回图片给前端选取

在 Flask 中,我们可以通过 send_file 方法返回图片以供前端进行下载和选择。下面是一个例子:

from flask import Flask, send_file

app = Flask(__name__)

@app.route('/images/')

def images(filename):

return send_file('images/' + filename, mimetype='image/png')

if __name__ == '__main__':

app.run(debug=True)

在这个例子中,我们将图片存储在 Flask 目录下的 images 文件夹中,并通过 send_file 方法返回。我们可以在前端页面中使用 img 标签来调用这个方法,并显示图片。

相关阅读

评论可见,请评论后查看内容,谢谢!!!评论后请刷新页面。