Python导入MySQLdb:未加载库:libmysqlclient.18.dylib

时间:2016-12-01 08:18:13

标签: python mysql macos mysql-python

macOS Sierra 10.12.1

MySQL 5.7.16

MySQL-python 1.2.5

Python 2.7

=======================================

当我

    import MySQLdb

它显示错误如下

    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
      File "build/bdist.macosx-10.6-intel/egg/MySQLdb/__init__.py", line 19, in <module>
      File "build/bdist.macosx-10.6-intel/egg/_mysql.py", line 7, in <module>
      File "build/bdist.macosx-10.6-intel/egg/_mysql.py", line 6, in __bootstrap__
    ImportError: dlopen(/Users/aldirc/.python-eggs/MySQL_python-1.2.5-py2.7-macosx-10.6-intel.egg-tmp/_mysql.so, 2): Library not loaded: libmysqlclient.18.dylib
      Referenced from: /Users/aldirc/.python-eggs/MySQL_python-1.2.5-py2.7-macosx-10.6-intel.egg-tmp/_mysql.so
      Reason: image not found   

我已尝试将Python mysqldb: Library not loaded: libmysqlclient.18.dylib称为

    $ sudo install_name_tool -change libmysqlclient.18.dylib  /usr/local/mysql-5.7.16-osx10.11-x86_64/lib/libmysqlclient.20.dylib  /Users/aldirc/Downloads/MySQL-python-1.2.5/build/lib.macosx-10.6-intel-2.7/_mysql.so

    $ sudo install_name_tool -change libmysqlclient.18.dylib  /usr/local/mysql-5.7.16-osx10.11-x86_64/lib/libmysqlclient.20.dylib  /Users/aldirc/.python-eggs/MySQL_python-1.2.5-py2.7-macosx-10.6-intel.egg-tmp/_mysql.so

    $ sudo ln -s /usr/local/mysql-5.7.16-osx10.11-x86_64/lib/libmysqlclient.20.dylib /usr/lib/libmysqlclient.18.dylib

但他们都行不通!

现在我该如何解决?

1 个答案:

答案 0 :(得分:0)

您可以使用像pymysql或sqlalchemy这样的包

使用pymysql

import pymysql.cursors
mysql_connection = pymysql.connect(host=hostname,
                         user=username,
                         password=password,
                         db=database,
                         charset='utf8mb4',
                         cursorclass=pymysql.cursors.DictCursor)

使用SqlAlchemy

import sqlalchemy 
from sqlalchemy import create_engine

sql_connection = 'mysql+mysqldb://'+str(user)+':'+str(password)+'@'+str(host)+'/'+str(database)+'?charset=utf8mb4'
mysql_connection = create_engine(sql_connection, echo=False, pool_recycle = 3600,pool_size=1000)