当前位置:   article > 正文

Mac安装Mysql-python遇到的坑,被这俩报错反复摩擦:'my_config.h' file not found 和 IndexError: string index out of range...

mysql.h file not found

最后Stackoverflow上面的大神解决了问题: Link

  1. brew install mysql
  2. brew unlink mysql
  3. brew install mysql-connector-c
  4. sed -i -e 's/libs="$libs -l "/libs="$libs -lmysqlclient -lssl -lcrypto"/g' /usr/local/bin/mysql_config
  5. pip install MySQL-python
  6. brew unlink mysql-connector-c
  7. brew link --overwrite mysql

尤其这条 sed -i -e 's/libs="$libs -l "/libs="$libs -lmysqlclient -lssl -lcrypto"/g' /usr/local/bin/mysql_config
解决了配置文件的问题,最后安装成功了


以上
作者:Jorah_Bronn
来源:CSDN
原文:https://blog.csdn.net/Eri_Feng/article/details/81224106
版权声明:本文为博主原创文章,转载请附上博文链接!

以上实测,我反正是没有搞定
又修改了下mysql_config实现了:
sed -i -e 's/libs="$libs -lmysqlclient -lssl -lcrypto"/# libs="$libs -l "/g' /usr/local/bin/mysql_config

安装好MySQLdb后,在python环境中导入MySQLdb,可能遇到如下问题:

  1. >>> import MySQLdb
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. File "/Library/Python/2.7/site-packages/MySQLdb/__init__.py", line 19, in <module>
  5. import _mysql
  6. ImportError: dlopen(/Library/Python/2.7/site-packages/_mysql.so, 2): Library not loaded: @rpath/libmysqlclient.21.dylib
  7. Referenced from: /Library/Python/2.7/site-packages/_mysql.so
  8. Reason: image not found

为了解决上述问题,你可能需要:

otool -L /Library/Python/2.7/site-packages/_mysql.so

该命令的结果可能是:

  1. /Library/Python/2.7/site-packages/_mysql.so:
  2. @rpath/libmysqlclient.21.dylib (compatibility version 21.0.0, current version 21.0.0)
  3. libssl.1.0.0.dylib (compatibility version 1.0.0, current version 1.0.0)
  4. libcrypto.1.0.0.dylib (compatibility version 1.0.0, current version 1.0.0)
  5. /usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 1252.50.4)

对此,你需要将前三个lib的位置重新写一下,具体命令:

  1. sudo install_name_tool -change @rpath/libmysqlclient.21.dylib /usr/local/mysql/lib/libmysqlclient.21.dylib /Library/Python/2.7/site-packages/_mysql.so
  2. sudo install_name_tool -change libssl.1.0.0.dylib /usr/local/mysql/lib/libssl.1.0.0.dylib /Library/Python/2.7/site-packages/_mysql.so
  3. sudo install_name_tool -change libcrypto.1.0.0.dylib /usr/local/mysql/lib/libcrypto.1.0.0.dylib /Library/Python/2.7/site-packages/_mysql.so

最终,可以看到不再报错:

  1. >>> import MySQLdb
  2. >>>
  3. >>>

此外,你可能遇到的问题:

  1. >>> import MySQLdb
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. File "/Library/Python/2.7/site-packages/MySQLdb/__init__.py", line 19, in <module>
  5. import _mysql
  6. ImportError: dlopen(/Library/Python/2.7/site-packages/_mysql.so, 2): Symbol not found: _mysql_affected_rows
  7. Referenced from: /Library/Python/2.7/site-packages/_mysql.so
  8. Expected in: flat namespace
  9. in /Library/Python/2.7/site-packages/_mysql.so

这个问题的原因是,你的Pyhon和Mysql的版本不一致导致的。
检查python的版本

  1. import platform
  2. platform.architecture()

比如我的mysql版本是64位,mac自带的python版本是2.7.10(32 bit)。我自己的解决方法是重新下载了python2.7.15(64bit),并做了如下配置(vim ~/.bash_profile):

  1. PATH="/usr/local/mysql/bin:${PATH}"
  2. export PATH
  3. export DYLD_LIBRARY_PATH=/usr/local/mysql/lib/
  4. export VERSIONER_PYTHON_PREFER_64_BIT=yes
  5. export VERSIONER_PYTHON_PREFER_32_BIT=no

转载于:https://www.cnblogs.com/icxy/p/11187934.html

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/喵喵爱编程/article/detail/951040
推荐阅读
相关标签
  

闽ICP备14008679号