ImportError: No module named 'MySQLdb'

本文介绍了一种常见问题,即在使用Python的SQLAlchemy库时遇到的“没有名为MySQLdb的模块”错误,并提供了解决方案。通过安装pymysql库并将其设置为MySQLdb的替代品,可以轻松解决此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

报错

Traceback (most recent call last):
  File "/home/as/anaconda3/envs/superset/bin/superset", line 12, in <module>
    from superset.cli import manager
  File "/home/as/anaconda3/envs/superset/lib/python3.4/site-packages/superset/__init__.py", line 89, in <module>
    utils.pessimistic_connection_handling(db.engine)
  File "/home/as/anaconda3/envs/superset/lib/python3.4/site-packages/flask_sqlalchemy/__init__.py", line 893, in engine
    return self.get_engine(self.get_app())
  File "/home/as/anaconda3/envs/superset/lib/python3.4/site-packages/flask_sqlalchemy/__init__.py", line 910, in get_engine
    return connector.get_engine()
  File "/home/as/anaconda3/envs/superset/lib/python3.4/site-packages/flask_sqlalchemy/__init__.py", line 545, in get_engine
    self._engine = rv = sqlalchemy.create_engine(info, **options)
  File "/home/as/anaconda3/envs/superset/lib/python3.4/site-packages/sqlalchemy/engine/__init__.py", line 387, in create_engine
    return strategy.create(*args, **kwargs)
  File "/home/as/anaconda3/envs/superset/lib/python3.4/site-packages/sqlalchemy/engine/strategies.py", line 80, in create
    dbapi = dialect_cls.dbapi(**dbapi_args)
  File "/home/as/anaconda3/envs/superset/lib/python3.4/site-packages/sqlalchemy/dialects/mysql/mysqldb.py", line 110, in dbapi
    return __import__('MySQLdb')
ImportError: No module named 'MySQLdb'

解决
打开home/as/anaconda3/envs/superset/lib/python3.4/site-packages/sqlalchemy/dialects/mysql/mysqldb.py
添加

import pymysql
pymysql.install_as_MySQLdb()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值