运行Python程序时出现此错误airflow:
问题$airflow
Traceback (most recent call last):
File "/home/idx/.virtualenvs/airflow/bin/airflow", line 16, in
from airflow import configuration
File "/home/idx/.virtualenvs/airflow/lib/python2.7/site-packages/airflow/__init__.py", line 31, in
from airflow import settings
File "/home/idx/.virtualenvs/airflow/lib/python2.7/site-packages/airflow/settings.py", line 150, in
configure_orm()
File "/home/idx/.virtualenvs/airflow/lib/python2.7/site-packages/airflow/settings.py", line 136, in configure_orm
engine = create_engine(SQL_ALCHEMY_CONN, **engine_args)
File "/home/idx/.virtualenvs/airflow/lib/python2.7/site-packages/sqlalchemy/engine/__init__.py", line 419, in create_engine
return strategy.create(*args, **kwargs)
File "/home/idx/.virtualenvs/airflow/lib/python2.7/site-packages/sqlalchemy/engine/strategies.py", line 80, in create
dbapi = dialect_cls.dbapi(**dbapi_args)
File "/home/idx/.virtualenvs/airflow/lib/python2.7/site-
packages/sqlalchemy/dialects/mysql/mysqldb.py", line 102, in dbapi
return __import__('MySQLdb')
File "/home/idx/.virtualenvs/airflow/lib/python2.7/site-packages/MySQLdb/__init__.py", line 23, in
(version_info, _mysql.version_info))
ImportError: this is MySQLdb version (1, 2, 5, 'final', 1), but _mysql is version (1, 4, 1, 'final', 0)
背景
我使用的MySQLdb位于:/home/will/.local/lib/python2.7/site-packages/MySQLdb/。目录中的cat release.py显示了1.2.5 final 1。__author__ = "Andy Dustman "
version_info = (1,2,5,'final',1)
__version__ = "1.2.5"
修复
为了使版本匹配,我运行了下面的代码,然后修复了它:# for some reason, even though I had mysqlclient==1.4.1 from pip freeze, I had to uninstall it first, then reinstall
pip uninstall mysqlclient
pip install mysqlclient==1.4.1