Mac环境下为Python安装MySQLdb库时遇到的诸多问题

跟着The Django Book的节奏今天学到了第五章-模型;结果就只是在Mac环境下为Python安装MySQLdb库时遇到的诸多问题。花了四个多小时终于把问题解决了,并且成功创建了我的第一个django app的第一个database 和 table。趁现在还有点记忆,把中途遇到的各种问题汇总如下,我相信将来肯定还是会有很多人遇到。

在Mac下安装和配置MySQL 应该是很简单的操作,不过我还真遇到一点小问题,教程可以移步看这篇文章 >>> http://www.cnblogs.com/macro-cheng/archive/2011/10/25/mysql-001.html

在选择MySQL版本下载的时候,你的Mac应该是64位的。如果不那么确定,可以『关于本机>更多信息>系统报告>软件>偏好设置面板:64位,是』

安装Python的MySQLdb库 我用的是比较笨的方法,小白可以参考 下载地址:http://sourceforge.net/projects/mysql-python/files/

然后,痛苦的节奏就开始了!!!

解压缩到桌面MySQLdb/

终端进入MySQLdb目录

cd desktop/MySQLdb

执行以下指令

python setup.py build

如果你跟我一样不幸的话,你会遇到跟我一样的报错

sh: mysql_config: command not found
Traceback (most recent call last):
  File "setup.py", line 18, in <module>
    metadata, options = get_config()
  File "/Users/daodao/Desktop/Mysql/setup_posix.py", line 43, in get_config
    libs = mysql_config("libs_r")
  File "/Users/daodao/Desktop/Mysql/setup_posix.py", line 25, in mysql_config
    raise EnvironmentError("%s not found" % (mysql_config.path,))
EnvironmentError: mysql_config not found

仔细看下报错信息中的关键词,这个时候,你需要在修改MySQLdb目录下面的setup_posix.py的配置信息

mysql_config.path = "mysql_config"

修改为我本机的mysqlconfig配置路径,我的mysqlconfig路径是/usr/local/mysql-5.6.14-osx10.7-x8664/bin/mysqlconfig,你可以查看下你自己的路径,目录结构应该是一样的。不知道怎么打开这个/usr?很简单——打开一个finder,『前往>前往服务器:usr/』,然后你自己找下 :

mysql_config.path = "/usr/local/mysql-5.6.14-osx10.7-x86_64/bin/mysql_config"

修改config后,我想应该没问题了把,所以继续一开始的操作,执行setup.py build。好吧,然后还是继续报错,这次跟Xcode相关(我曾经安装过Xcode,后来删了,所以本机没有Xcode开发环境),报错信息是:

xcrun: error: active developer path ("/Applications/Xcode.app/Contents/Developer") does not exist, use xcode-select to change
error: command '/usr/bin/clang' failed with exit status 1

郁闷了,我在Python下面装MySQL,跟Xcode有毛关系?!前面一些问题网上其实都还比较容易找到解决办法,但是这个问题,网上死活也找不到!最后无奈抱着试一试的想法,重新下载安装了下Xcode,继续尝试setup.py build操作。

好吧,问题解决了!不是特别清楚什么原因,但是听网上有人说好像是因为Python MySQL环境需要安装GCC,而Xcode里面的command_line_tools 支持GCC。你可以不去管Xcode,自己安装GGC的环境,我现在还没研究啥叫GGC,先不管了。

——————————11月3日更新————————————

commandlinetools 包可以直接从苹果服务器上下载到,但是你需要有Apple开发者账号,没有?可以看这里:http://railsapps.github.io/xcode-command-line-tools.html

我稍有洁癖,重新执行一遍吧,顺便加深下对操作的理解。

—————————————————————————————————

python setup.py clean
python setup.py build
sudo python setup.py install

执行到这里都没有再报错了。但是问题还在继续,终端进入Python测试效果

import MySQLdb

还是不怎么顺利。。。报错:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/MySQL_python-1.2.4b4-py2.7-macosx-10.6-intel.egg/MySQLdb/__init__.py", line 19, in <module>
    import _mysql
ImportError: dlopen(/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/MySQL_python-1.2.4b4-py2.7-macosx-10.6-intel.egg/_mysql.so, 2): Library not loaded: libmysqlclient.18.dylib
  Referenced from: /Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages/MySQL_python-1.2.4b4-py2.7-macosx-10.6-intel.egg/_mysql.so
  Reason: image not found

网上找了一圈,问题解决方法是:

用vi指令在 User/打开 .bash_profile 文件,这是一个隐藏文件。

vi .bash_profile

进入编辑状态,在最后添加

export DYLD_LIBRARY_PATH="/usr/local/mysql/lib"

:wq 保存退出终端

重新切换到Python开发环境下, import MySQLdb 返回正常。问题搞定了,但是暂时还不明白什么原理。先留着,以后搞懂了之后再回来更新文章。

继续在终端中输入 mysql -uroot

反馈:-bash: mysql: command not found。这个问题我大概知道,是由于系统默认会查找/usr/bin下的命令,如果这个命令不在这个目录下,我们需要做的就是映射一个链接到/usr/bin目录下,相当于建立一个链接文件。 首先得知道mysql命令或mysqladmin命令的完整路径,比如mysql的路径是:/usr/local/mysql/bin/mysql,然后执行命令:

ln -s /usr/local/mysql/bin/mysql /usr/bin

O了!后面的操作一切顺利!

    原文作者:盗盗
    原文地址: https://segmentfault.com/a/1190000000329202
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞