Windows下安装python MySQLdb遇到的问题及解决方法


Posted in Python onMarch 16, 2017

片头语:因为工作需要,在CentOS上搭建环境MySQL+Python+MySQLdb,个人比较习惯使用Windows系统的操作习惯,对纯字符的OS暂时还不太习惯,所以,希望能在Windows系统上也搭建一个类似的环境,用于开发。下面介绍的是在Windows环境下编译MySQLdb的过程。补充一句:最近在网上搜索到一个MySQLdb的Windows安装包,使用起来会更方便一些,地址:http://www.codegood.com/archives/4

或者到 https://3water.com/softs/73369.html下载当然也可以到https://dev.mysql.com/downloads/connector/python/下载

mysql-connector-python是MySQL官网提供的专门连接python的驱动程序;使用起来很方便。文件里面有很多程序实例供参考。

手工编译MySQLdb的过程如下:

下面列举出上面需要用到的软件的下载地址:

 MySQL - http://www.mysql.com/  <个人使用的MySQL的版本:mysql-essential-5.1.53-win32.msi,也许您下载的时候已经有新的版本了。>

Python - http://www.python.org/  <个人使用的Python版本:python-2.6.6.msi>

MySQLdb - http://sourceforge.net/projects/mysql-python/  <个人使用的MySQLdb版本:MySQL-python-1.2.3.tar.gz>

 

1、安装MySQL,选择Custom,然后将“C Include Files / Lib Files”勾选上,如果使用Typical,则会出现问题(1),后面的配置也基本上都是默认选项,除了额外将"添加到系统路径"(Include Bin Directory in Windows PATH)这个复选框勾上。如果你对安装MySQL不是很清楚,可以从网上搜索一下,相关的文章很多,如下:http://rangyang163.blog.163.com/blog/static/37743758200881203744469/

2、安装Python,也基本上默认的选项,只是把安装路径稍微改了一下。Python的默认安装路径是"C:/Python26",个人习惯将其改为"C:/Program Files/Python26"

3、在安装MySQLdb之前必须安装setuptools,要不然会出现编译错误。

 

Setuptools - http://pypi.python.org/pypi/setuptools   <将滚动条向下拖,很快,就可以看到一串下载地址,个人使用的是:setuptools-0.6c11.win32-py2.6.exe,这是因为我使用的Python版本是2.66>

默认安装这个工具即可...

 

好了,可以正式开始安装MySQLdb了,我们下载的这个tar.gz是源码包,里面是没有安装程序的,需要先编译,再安装。<其实只要看看README就明白了。>

(1)将MySQL-python-1.2.3.tar.gz解压到当前目录下,会出现一个MySQL-python-1.2.3文件夹;

(2)WIN+R,打开运行对话框,输入cmd,打开MS-DOS,进入上面解压的那个文件夹;(前提是你得明白cd是什么命令 :-)....)

(3)输入setup.py build开始编译...<额外补充一点,在编译MySQLdb时需要C编译器,如果已经安装了MSVC,则直接编译即可。如果需要指定编译器,可以使用compiler开关。如--compiler=mingw32则使用GCC作为编译器,不过,前提是你需要安装相应的编译器,并配置好环境变量才行。>

我在编译过程中遇到以下问题:

1)问题: _mysql.c(34) : fatal error C1083: Cannot open include file: ‘config-win.h': No such file or directory
error: command ‘”C:/Program Files/Microsoft Visual Studio 9.0/VC/BIN/cl.exe”‘ failed with exit status 2

原因:原因是安装MySQL的时候没有安装C语言库。

解决:重新运行MySQL的安装程序,选择Modify,把“C Include Files / Lib Files”勾选上,并安装。

2)问题:Traceback (most recent call last):
  File "setup.py", line 15, in <module>
    metadata, options = get_config()
  File "C:/MySQL-python-1.2.3/setup_windows.py", line 7, in get_config
    serverKey = _winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE, options['registry_key'])
WindowsError: [Error 2] The system cannot find the file specified

原因:MySQL for python 1.2.3仍然是在寻找MySQL5.0的版本

解决:1、打开目录下site.cfg文件,修改最后一行为“registry_key = SOFTWARE/MySQL AB/MySQL Server 5.1”
2、打开setup_windows.py文件,修改第七行为“serverKey = _winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE, 'SOFTWARE/MySQL AB/MySQL Server 5.1')”

3)问题:build/temp.win32-2.7/Release/_mysql.pyd.manifest : general error c1010070: Failed to load and parse the manifest. The system cannot find the file specified.
error: command ‘mt.exe' failed with exit status 31

原因:路径发生变化?

解决:打开“你的PYTHON安装目录/Lib/distutils/msvc9compiler.py”文件,找到“ld_args.append('/MANIFESTFILE:' + temp_manifest)”这行代码,将其改为“ld_args.append('/MANIFEST')”

(4)当编译完成以后,就可以输入setup.py install了,现在终于大功告成了!

可以在DOS环境下输入以下命令进行测试:

C:/Users/Michael>python
Python 2.6.6 (r266:84297, Aug 24 2010, 18:46:32) [MSC v.1500 32 bit (Intel)] on
win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import MySQLdb
>>>

这样就说明MySQLdb已经成功安装了!接下来,就可以学习Python+MySQLdb+MySQL了,祝你愉快!

Python 相关文章推荐
Python编码时应该注意的几个情况
Mar 04 Python
python中的hashlib和base64加密模块使用实例
Sep 02 Python
Python中Django 后台自定义表单控件
Mar 28 Python
mysql 之通过配置文件链接数据库
Aug 12 Python
pandas数据分组和聚合操作方法
Apr 11 Python
python3+PyQt5图形项的自定义和交互 python3实现page Designer应用程序
Jul 20 Python
Django rest framework实现分页的示例
May 24 Python
python消除序列的重复值并保持顺序不变的实例
Nov 08 Python
python运行时强制刷新缓冲区的方法
Jan 14 Python
python 阶乘累加和的实例
Feb 01 Python
完美解决pyinstaller打包报错找不到依赖pypiwin32或pywin32-ctypes的错误
Apr 01 Python
深入浅析Django MTV模式
Sep 04 Python
python Selenium爬取内容并存储至MySQL数据库的实现代码
Mar 16 #Python
python开发利器之ulipad的使用实践
Mar 16 #Python
离线安装Pyecharts的步骤以及依赖包流程
Apr 23 #Python
Python中%r和%s的详解及区别
Mar 16 #Python
Python 装饰器深入理解
Mar 16 #Python
WINDOWS 同时安装 python2 python3 后 pip 错误的解决方法
Mar 16 #Python
Django卸载之后重新安装的方法
Mar 15 #Python
You might like
PHP XML操作的各种方法解析(比较详细)
2010/06/17 PHP
CodeIgniter框架提示Disallowed Key Characters的解决办法
2014/04/21 PHP
PHP汉字转换拼音的函数代码
2015/12/30 PHP
php 使用html5实现多文件上传实例
2016/10/24 PHP
Laravel5.5 动态切换多语言的操作方式
2019/10/25 PHP
JavaScript中“+=”的应用
2007/02/02 Javascript
初步使用Node连接Mysql数据库
2016/03/03 Javascript
IScroll5 中文API参数说明和调用方法
2016/05/21 Javascript
js实现5秒倒计时重新发送短信功能
2017/02/05 Javascript
微信小程序 常用工具类详解及实例
2017/02/15 Javascript
JS实现动态修改table及合并单元格的方法示例
2017/02/20 Javascript
angular-tree-component的使用详解
2018/07/30 Javascript
JavaScript函数定义方法实例详解
2019/03/05 Javascript
vue自定义树状结构图的实现方法
2020/10/18 Javascript
基于python编写的微博应用
2014/10/17 Python
Python中使用第三方库xlrd来读取Excel示例
2015/04/05 Python
Python编程中对super函数的正确理解和用法解析
2016/07/02 Python
python 实现上传图片并预览的3种方法(推荐)
2017/07/14 Python
Python编程之变量赋值操作实例分析
2017/07/24 Python
对python中的iter()函数与next()函数详解
2018/10/18 Python
在python中按照特定顺序访问字典的方法详解
2018/12/14 Python
python如何获取当前文件夹下所有文件名详解
2019/01/25 Python
python创建与遍历List二维列表的方法
2019/08/16 Python
python利用xlsxwriter模块 操作 Excel
2020/10/14 Python
简单的HTML5初步入门教程
2015/09/29 HTML / CSS
canvas实现滑动验证的实现示例
2020/08/11 HTML / CSS
英国最大的在线蜡烛商店:Candles Direct
2019/03/26 全球购物
JDBC操作数据库的基本流程是什么
2014/10/28 面试题
物理专业大学生职业生涯规划书
2014/02/07 职场文书
信息与计算科学专业推荐信
2014/02/23 职场文书
书香校园建设方案
2014/05/02 职场文书
法制宣传标语集锦
2014/06/25 职场文书
学生安全责任书模板
2014/07/25 职场文书
2015年公司国庆放假通知
2015/07/30 职场文书
windows安装python超详细图文教程
2021/05/21 Python
winserver2019安装软件一直卡在应用程序正在为首次使用做准备
2022/06/10 Servers