Flask 返回 Json
作者:mmseoamin日期:2023-12-25

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 标签来调用这个方法,并显示图片。