注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

@fc_lamp

关注Web应用解决方案MySql/PHP/Python一盏名为"飞川"的灯~

 
 
 

日志

 
 

Python,Django安装MySQLdb各种经典错误(Error No module named MySQLdb)  

2012-03-02 17:06:00|  分类: Web技术-Python |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

Python,Django安装MySQLdb各种经典错误(Error No module named MySQLdb)

前文:

这几日有些闲,于就想把前面断断续续学习Django WEB框架真正搭建起来,并使用mysql数据库。可是,真正在搭建过程中遇到了各式各样的错误。因此,在此特别记录一下。

(python shell 里能正常import MySQLdb 模块,但是Django里manage.py runserver 报错:No module named MySQLdb,见第四错)

 

准备工作:

首先肯定得先安一个python,实际上我机子上已经有了2.7版的了,不过为学习Django我又上官网去下载了一个python2.6版本的。

之后又去Django官网下载了最新的Django框架,并上http://sourceforge.net/projects/mysql-python/  去下载了window 版本的MySQLdb。

Django,MySQLdb都到 python2.6安装目录下的 lib/site-packages/里(实际上:下载Django window版后,解压里面的文件目录只copy 

django目录就OK了)。

一切安装好后,开始import 工作了。

第一个错误:

Traceback (most recent call last):

  File "<pyshell#1>", line 1, in <module>

    import MYSQLdb

ImportError: No module named MYSQLdb

原因

模块名称写错了把MySQLdb写成了MYSQLdb

解决方法:大虾们一定学好E文!Python,Django安装MySQLdb各种经典错误(Error No module named MySQLdb) - fc-lamp - fc-lamp的博客

第二错误:

import MySQLdb

Traceback (most recent call last):

  File "<pyshell#2>", line 1, in <module>

    import MySQLdb

  File "D:\PythonDev26\Lib\site-packages\MySQLdb\__init__.py", line 19, in <module>

    import _mysql

ImportError: DLL load failed: 找不到指定的模块。

 

原因:花了一定时间去google,baidu,发现原来window 版本的MySQLdb需要两个dll文件的支持。

解决方法:参考《在python中使用MySQL》,再运行 import MySQLdb,又出现错误信息了。Python,Django安装MySQLdb各种经典错误(Error No module named MySQLdb) - fc-lamp - fc-lamp的博客

 

第三错误:

Warning (from warnings module):

  File "D:\PythonDev26\Lib\site-packages\MySQLdb\__init__.py", line 34

    from sets import ImmutableSet

DeprecationWarning: the sets module is deprecated

原因:看错误提示貌似是说 sets module 被弃用了。

解决方法:又花了一定时间去google,baidu。最终参考《在python中使用MySQL》

现在再在python shell里再运行“import MySQLdb” ,OK~~一切正常~

好了,现在要在Django里使用mysql了,不过在开始之前我们还得看看安装是否正常:

import  sys

import  django

import  MySQLdb

print sys.version_info

print django.VERSION

print MySQLdb.version_info

输出:

(2, 6, 6, 'final', 0)

(1, 2, 7, 'final', 0)

(1, 2, 2, 'final', 0)

恩,只少说到目前为止一切正常。Python,Django安装MySQLdb各种经典错误(Error No module named MySQLdb) - fc-lamp - fc-lamp的博客

先按照官网手册进行,进入django/bin 目录里,打开cmd。输入 python django-admin.py startproject mysite 开始一个项目,进入刚才新建项目 mysite目录里,在cmd里运行 python manage.py runserver 开始一个开发用的web server。

恩,没有什么问题,通过http://localhost:8000/也能访问到像其官网所说“淡蓝色的,柔和”的页面。OK,我们开始配置数据库吧,进入settings.py里找到12行进行mysql数据库的配置:

 DATABASES = {

    'default': {

        'ENGINE': 'django.db.backends.mysql', # 数据库API'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.

        'NAME': 'test',                      # 数据库

        'USER': 'user',                      # 用户名

        'PASSWORD': '',                  # 密码

        'HOST': 'localhost',               # 主机地址

        'PORT': '3306',                      # 端口

    }

}

好,我们再重新run一次:python manage.py runserver

OH。。。。MY GOD......

怎么了????

 

第四个错误:

.... backend = __import__('%s%s.base' % (_import_path, settings.DATABASE_ENGINE),

{}, {}, [''])
  File "D:\Python\Python24\Lib\site-packages\django\db\backends\mysql\base.py",
line 13, in ?
    raise ImproperlyConfigured("Error loading MySQLdb module: %s" % e)
django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb module: No mo
dule named MySQLdb

原因:这是什么??怎么会这样?python shell 里import MySQLdb 也没有任何错误呀?????Python,Django安装MySQLdb各种经典错误(Error No module named MySQLdb) - fc-lamp - fc-lamp的博客

          查网络了半天,http://stackoverflow.com/questions/770904/installing-django-on-shared-server-no-module-named-mysqldb这家伙好像有这问题。最后在“laofo” 里找出原因:原来我之前装过python2.7,又在python里装过Django,并且设置过window环境变量路径Path和PYTHONPATH为python2.7的,但是没有装过MySQLdb,所以文件被关联到python2.7里了。

解决方法:重新设置一下环境变量,确保安装路径等是正确的。

 

 

 

PS:No module named MySQLdb 最经典

 

 



 

 

 

 

fc_lamp推荐阅读:
  评论这张
 
阅读(9245)| 评论(2)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017