app.config['JSON_AS_ASCII']=False在Flask中不起作用
时间: 2024-03-10 13:46:22 浏览: 26
如果在 Flask 中设置了 `app.config['JSON_AS_ASCII'] = False`,但是在生成 JSON 数据时仍然看到了 ASCII 编码的字符,那么可能是因为在生成 JSON 数据的时候,使用了 Flask 自带的 `jsonify` 方法。
Flask 中的 `jsonify` 方法默认会将生成的 JSON 数据中的非 ASCII 字符进行转义,这样就会导致设置 `app.config['JSON_AS_ASCII'] = False` 无效。
解决这个问题的方法是使用 Python 内置的 `json` 模块来生成 JSON 数据,或者使用第三方库如 `simplejson` 来生成 JSON 数据。这些库可以通过设置 `ensure_ascii` 参数为 `False` 来保留非 ASCII 字符。例如:
```python
from flask import Flask
import json
app = Flask(__name__)
app.config['JSON_AS_ASCII'] = False
@app.route('/')
def hello_world():
data = {'name': '张三', 'age': 18}
return json.dumps(data, ensure_ascii=False)
```
这样就可以在生成 JSON 数据时保留非 ASCII 字符。
相关问题
如何重写下列代码,实现类似ChatGPT官网式样的问答。另外如果没有收到返回值时,显示等待,并且禁止输入新的提问。from flask import Flask, jsonify #from flask_restful import Resource, Api import openai app = Flask(__name__) openai.api_key = "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" @app.route('/') def generate_text(): prompt = "如何做像肯德基一样的炸鸡?" try: response = openai.Completion.create( engine="text-davinci-002", prompt=prompt, max_tokens=1024, n=1, stop=None, temperature=0.5 ) return jsonify(response["choices"][0]["text"]) except openai.exceptions.OpenAiError as e: return jsonify(error=str(e)) except Exception as e: return jsonify(error=str(e)) if __name__ == '__main__': app.config['JSON_AS_ASCII'] = False app.run(debug=True)
为了实现类似ChatGPT官网样式的问答,可以使用JavaScript或jQuery在页面上实现实时输入和输出的功能。可以使用Ajax请求来与服务器进行通信,在服务器没有返回结果之前禁止用户输入新的提问。
下面是一个简单的示例代码:
```python
from flask import Flask, jsonify, request
app = Flask(__name__)
@app.route('/', methods=['GET', 'POST'])
def index():
if request.method == 'POST':
user_input = request.form['input']
# 在这里调用模型并处理用户输入
response = model.generate(user_input)
return jsonify({'response': response})
return '''
<form method="post">
<input type="text" name="input" id="input" onkeydown="if(event.keyCode==13)event.returnValue=false;">
<input type="button" value="Submit" onclick="submitForm()">
</form>
<script>
function submitForm(){
var input = document.getElementById('input').value;
if(input.trim() === '') return;
document.getElementById('input').setAttribute('readonly', true);
document.getElementById('input').value = "等待中...";
var xhr = new XMLHttpRequest();
xhr.open('POST', '/');
xhr.setRequestHeader('Content-Type', 'application/json');
xhr.onload = function() {
if (xhr.status === 200) {
var response = JSON.parse(xhr.responseText);
console.log(response);
document.getElementById('input').value = response.response;
document.getElementById('input').removeAttribute('readonly');
}
};
xhr.send(JSON.stringify({'input': input}));
}
</script>
'''
if __name__ == '__main__':
app.run()
```
这段代码将会在页面上显示一个简单的文本输入框和一个提交按钮。当用户在输入框中输入内容并按下提交按钮
app = Flask(__name__) app.config["JSON_AS_ASCII"]=False CORS(app,resources=r'/*') def sql_query_json(sql): #定义查询函数语句 con = pymysql.connect(host='127.0.0.1',user='root',password='root123456', port=3306,db='libsystem',charset='utf8mb4',cursorclass=cursors.DictCursor) cur = con.cursor() cur.execute(sql) all_obj = cur.fetchall() cur.close() con.close() print(all_obj) return all_obj def sql_ua_json(sql): con = pymysql.connect(host='127.0.0.1', user='root', password='root123456', port=3306, db='libsystem', charset='utf8mb4', cursorclass=cursors.DictCursor) cur = con.cursor() cur.execute(sql) con.commit() cur.close() con.close()解释每行代码意思
- `app = Flask(__name__)`: 创建一个 Flask 应用程序对象,`__name__` 参数表示当前模块的名称,可以根据当前模块的名称来确定应用程序的根路径。
- `app.config["JSON_AS_ASCII"]=False`: 将 Flask 应用程序的 JSON 编码设置为 UTF-8,以支持中文字符。
- `CORS(app,resources=r'/*')`: 创建一个 CORS 对象并传入 Flask 应用程序对象,`r'/*'` 参数表示允许所有来源的跨域请求。
- `def sql_query_json(sql):`: 定义一个函数,该函数接收一个 SQL 查询语句作为参数,并返回查询结果的 JSON 格式对象。
- `con = pymysql.connect(host='127.0.0.1',user='root',password='root123456',port=3306,db='libsystem',charset='utf8mb4',cursorclass=cursors.DictCursor)`: 创建一个 MySQL 数据库连接对象,`host` 参数表示连接的 MySQL 主机地址,`user` 参数表示连接的 MySQL 用户名,`password` 参数表示连接的 MySQL 密码,`port` 参数表示连接的 MySQL 端口号,`db` 参数表示连接的 MySQL 数据库,`charset` 参数表示连接的 MySQL 数据库的字符集,`cursorclass` 参数表示返回的游标类型。
- `cur = con.cursor()`: 创建一个游标对象。
- `cur.execute(sql)`: 执行 SQL 查询语句。
- `all_obj = cur.fetchall()`: 获取查询结果的所有行。
- `cur.close()`: 关闭游标对象。
- `con.close()`: 关闭 MySQL 数据库连接对象。
- `print(all_obj)`: 打印查询结果。
- `return all_obj`: 返回查询结果。
- `def sql_ua_json(sql):`: 定义一个函数,该函数接收一个 SQL 更新语句作为参数,并执行该语句更新数据库。