问题列表
近期学习Django,安装过程遇到不少坑。特此记下,方便以后查看。
笔者所用的python为2.7,django 版本为1.9.
1 . No module named MYSQLdb
出现这个问题的原因是缺少MYSQL-python依赖库, 如下为解决办法:
第一种办法:
pip install MYSQL-python
不过,这个办法通常是失败的。因为本地环境通常没有编译环境所依赖的库文件,但是可以通过第二种方法解决。
第二种办法:
1. 安装mysql的python驱动。(请注意下载的版本的位数(32位/64位))下载地址
2. 安装mysql-python模块。推荐大家使用whl文件进行安装(这里仍然要注意位数(32位/64位))。MySQL_python-1.2.5-cp27-none-win_amd64.whl
命令:
pip install wheel
pip install 本地whl文件地址
- 如果不想通过whl文件安装。window用户可以使用软件安装的方式安装。
3.1 下载软件。下载
3.2 设置环境变量。
安装过程中需要获取获取python的安装路径,而这个路径由于无法手动选择,可以通过执行以下代码来设置注册列表。
#
# script to register Python 2.0 or later for use with win32all
# and other extensions that require Python registry settings
#
# written by Joakim Loew for Secret Labs AB / PythonWare
#
# source:
# http://www.pythonware.com/products/works/articles/regpy20.htm
#
# modified by Valentine Gogichashvili as described in http://www.mail-archive.com/distutils-sig@python.org/msg10512.html
import sys
from _winreg import *
# tweak as necessary
version = sys.version[:3]
installpath = sys.prefix
regpath = "SOFTWARE\\Python\\Pythoncore\\%s\\" % (version)
installkey = "InstallPath"
pythonkey = "PythonPath"
pythonpath = "%s;%s\\Lib\\;%s\\DLLs\\" % (
installpath, installpath, installpath
)
def RegisterPy():
try:
reg = OpenKey(HKEY_CURRENT_USER, regpath)
except EnvironmentError as e:
try:
reg = CreateKey(HKEY_CURRENT_USER, regpath)
SetValue(reg, installkey, REG_SZ, installpath)
SetValue(reg, pythonkey, REG_SZ, pythonpath)
CloseKey(reg)
except:
print "*** Unable to register!"
return
print "--- Python", version, "is now registered!"
return
if (QueryValue(reg, installkey) == installpath and
QueryValue(reg, pythonkey) == pythonpath):
CloseKey(reg)
print "=== Python", version, "is already registered!"
return
CloseKey(reg)
print "*** Unable to register!"
print "*** You probably have another Python installation!"
if __name__ == "__main__":
RegisterPy()
3.3 一切前提都准备好了。双击安装程序即可。
2. 连接MySQL8.0版本时出现Client does not support authentication protocol requested by server
解决办法:
ALTER USER ’root‘’@’‘’ocalhost‘’ IDENTIFIED WITH mysql_native_password BY ‘密码’;
FLUSH PRIVILEGES;
3. raise ImproperlyConfigured(“Error loading MySQLdb module: %s” % e)
从错误的提示来看,似乎是配置不当的问题,但是通过debug,你会发现这个问题实际是mysql-python没有被正确安装或者安装不当。
如图:
在python的环境下载执行下述代码:
import MYSQLdb
可以会出现该错误:" ImportError DLL load failed: %1 不是有效的 Win32 应用程序"
这个问题实际上是mysql的python驱动的版本或者mysql-python这个库的版本的不一致的问题。
笔者在安装的mysql驱动为64位,但是mysql-python为32位。所以出现上述问题。
解决办法也很简单,统一位数即可。
参考资料:
1.Python开发中常见问题(python常见问题)
2.ImportError DLL load failed: %1 不是有效的 Win32 应用程序
3.Navicat连接MySQL8.0版本时出现Client does not support authentication protocol requested by server;报错的问题解决办法