TypeError:cursor()使用获取了意外的关键字参数“dictionary”flaskext.mysq

2024-06-16 13:35:58 发布

您现在位置:Python中文网/ 问答频道 /正文

我使用的是flask框架和MySQL数据库连接器。在

我做了以下事情:

from flaskext.mysql import MySQL
mysql = MySQL()
## app.config database configuration code
mysql.init_app(app)
conn = mysql.connect()
cursor = conn.cursor();
cursor.execute(
        'SELECT * FROM customer WHERE email = (%s)', (username,)
    )
user = cursor.fetchone()

我可以使用user[8]之类的索引访问用户列(我需要执行一次查询并检查列号),但是当我尝试指定

^{pr2}$

我知道错误了

'TypeError: cursor() got an unexpected keyword argument 'dictionary''

在使用flaskmysql时,有没有一种方法可以获得字典格式的查询结果?在


Tags: fromimport框架config数据库appflaskmysql
1条回答
网友
1楼 · 发布于 2024-06-16 13:35:58

你可以按照这个答案:https://stackoverflow.com/a/41388992/3129414

现有代码修改:

  • MySQL初始化中使用DictCursor
  • 从光标中删除dictionary=True
  • 使用json包将字典项转换为json格式

app.py

import json
from flask import Flask
from flaskext.mysql import MySQL
from pymysql.cursors import DictCursor

app = Flask(__name__)
app.config['MYSQL_DATABASE_USER'] = 'root'
app.config['MYSQL_DATABASE_PASSWORD'] = '123'
app.config['MYSQL_DATABASE_DB'] = 'practice_db'
app.config['MYSQL_DATABASE_HOST'] = 'localhost'
mysql = MySQL(cursorclass=DictCursor)
mysql.init_app(app)
conn = mysql.connect()

@app.route("/", methods=['GET'])
def home():
    email_address = 'dummy@example.com'
    cursor = conn.cursor();
    cursor.execute(
            'SELECT * FROM user_table WHERE email = (%s)', (email_address,)
        )
    users = cursor.fetchall()
    return json.dumps(users)

app.run(debug=True)

截图:

dictionary output using flaskext

相关问题 更多 >