MySQL Connector / Python-вставить переменную python в таблицу MySQL

Я пытаюсь вставить переменную python в таблицу MySQL в скрипте python, но она не работает. Вот мой код

add_results=("INSERT INTO account_cancel_predictions"
            "(account_id,21_day_probability,flagged)"
            "Values(%(account_id)s,%(21_day_probability)s,%(flagged)s)")

data_result={
    'account_id':result[1,0],
    '21_day_probability':result[1,1],
    'flagged':result[1,2]
}

cursor.execute(add_results,data_result)

cnx.commit()
cursor.close()
cnx.close()

Это получает ошибку

ProgrammingError: Failed processing pyformat-parameters; 'MySQLConverter' object has no attribute '_float64_to_mysql'

однако, когда я заменяю имена переменных result[1,0], result[1,1] и result[1,2] С их фактическими числовыми значениями он работает. Я подозреваю, что python передает фактические имена переменных, а не значения, которые они содержат. Как это исправить?

3 ответов


Если вы используете mysql.connector (Я думаю, что вы), определите свой собственный класс конвертера:

class NumpyMySQLConverter(mysql.connector.conversion.MySQLConverter):
    """ A mysql.connector Converter that handles Numpy types """

    def _float32_to_mysql(self, value):
        return float(value)

    def _float64_to_mysql(self, value):
        return float(value)

    def _int32_to_mysql(self, value):
        return int(value)

    def _int64_to_mysql(self, value):
        return int(value)

config = {
    'user'    : 'user',
    'host'    : 'localhost',
    'password': 'xxx',
    'database': 'db1'
}

conn = mysql.connector.connect(**config)
conn.set_converter_class(NumpyMySQLConverter)

одно из ваших переданных значений может иметь тип numpy.float64 который не распознается соединителем MySQL. Бросьте его на подлинный python float при заполнении дикт.


Если вы находитесь на python 3 и выше, просто используйте mysqlclient pip install mysqlclient. Это рекомендуется django, и все остальные драйверы плохие.