使用 PostgreSQL (psycopg2) 和 Django 运行 Python 3.4 时出错
Posted
技术标签:
【中文标题】使用 PostgreSQL (psycopg2) 和 Django 运行 Python 3.4 时出错【英文标题】:Error running Python 3.4 with PostgreSQL (psycopg2) and Django 【发布时间】:2015-03-06 15:59:17 【问题描述】:所以如果我用python
启动Python 2.7 的shell,然后运行import psycopg2
,我不会收到任何错误。但是,如果我尝试在 Python 3.4 的 shell 中运行 import psycopg2
,我会得到:ImportError: No module named 'psycopg2'
。另一方面,导入 django 在两个 shell 上都可以正常工作(使用 pip3 安装后)。
其次,如果我运行python3 manage.py runserver
,我会收到一个错误(见下文),而如果我只使用python
,我不会。我认为这是因为我描述的第一个问题,但我不确定(对不起,如果这是一个愚蠢的问题,我对 Django 真的很陌生 - 试图通过教程)。
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/db/backends/postgresql_psycopg2/base.py", line 23, in < module >
import psycopg2 as Database
ImportError: No module named 'psycopg2'
During handling of the above exception, another exception occurred:
Traceback(most recent call last):
File "manage.py", line 10, in < module >
execute_from_command_line(sys.argv)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/core/management/__init__.py", line 385, in execute_from_command_line
utility.execute()
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/core/management/__init__.py", line 354, in execute
django.setup()
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/__init__.py", line 21, in setup
apps.populate(settings.INSTALLED_APPS)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/apps/registry.py", line 108, in populate
app_config.import_models(all_models)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/apps/config.py", line 202, in import_models
self.models_module = import_module(models_module_name)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/importlib/__init__.py", line 109, in import_module
return _bootstrap._gcd_import(name[level: ], package, level)
File "<frozen importlib._bootstrap>", line 2254, in _gcd_import
File "<frozen importlib._bootstrap>", line 2237, in _find_and_load
File "<frozen importlib._bootstrap>", line 2226, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 1200, in _load_unlocked
File "<frozen importlib._bootstrap>", line 1129, in _exec
File "<frozen importlib._bootstrap>", line 1471, in exec_module
File "<frozen importlib._bootstrap>", line 321, in _call_with_frames_removed
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/contrib/auth/models.py", line 40, in < module >
class Permission(models.Model):
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/db/models/base.py", line 122, in __new__
new_class.add_to_class('_meta', Options(meta, * * kwargs))
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/db/models/base.py", line 297, in add_to_class
value.contribute_to_class(cls, name)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/db/models/options.py", line 166, in contribute_to_class
self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/db/__init__.py", line 40, in __getattr__
return getattr(connections[DEFAULT_DB_ALIAS], item)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/db/utils.py", line 242, in __getitem__
backend = load_backend(db['ENGINE'])
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/db/utils.py", line 108, in load_backend
return import_module('%s.base' % backend_name)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/importlib/__init__.py", line 109, in import_module
return _bootstrap._gcd_import(name[level: ], package, level)
File "<frozen importlib._bootstrap>", line 2254, in _gcd_import
File "<frozen importlib._bootstrap>", line 2237, in _find_and_load
File "<frozen importlib._bootstrap>", line 2226, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 1200, in _load_unlocked
File "<frozen importlib._bootstrap>", line 1129, in _exec
File "<frozen importlib._bootstrap>", line 1471, in exec_module
File "<frozen importlib._bootstrap>", line 321, in _call_with_frames_removed
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/django/db/backends/postgresql_psycopg2/base.py", line 27, in < module >
raise ImproperlyConfigured("Error loading psycopg2 module: %s" % e)
django.core.exceptions.ImproperlyConfigured: Error loading psycopg2 module: No module named 'psycopg2'
我能做些什么来解决它?
此外,我对 Django 的整个 Python 2 vs 3 业务感到非常困惑(如果这是一个非常基本的问题,再次抱歉)。当您运行django-admin.py startproject theproject
时,如何指定要与 Django 一起使用的 Python 版本?是否就像在 Python 3 中编写代码并使用 python3
而不是 python
运行所有内容一样简单?
【问题讨论】:
您已经运行pip3 install psycopg2
了吗?有没有报错?
【参考方案1】:
确保您已运行 pip3 install psycopg2。
默认情况下,django-admin.py
将使用 Python 2 运行。这无关紧要,因为它所做的只是创建项目的文件夹布局。
创建项目后,您可以编写 Python 3 代码,并使用 python3 manage.py runserver
运行您的网站以使用 Python 3。
稍后,您可能想要研究虚拟环境。如果您创建虚拟环境以使用 Python 3
virtualenv v -p python3
然后就可以运行了
./manage.py runserver
在您的虚拟环境中,它将使用 Python 3。
【讨论】:
我正在运行 OS X(忘记指定),但是安装psycopg2
和 pip3
确实成功了,错过了。如果我不使用 virtualenv,现在运行 django-admin.py
是否意味着我将使用 Python 3?或者在任何情况下都没有关系,我可以使用 2 或 3?
是的,运行python3 manage.py runserver
就足够了。我已经更新了我的答案,希望它更有意义。【参考方案2】:
我在 Mac 上使用 virtualenv 从 Python 2.7 切换到 Python 3 时遇到了同样的问题。显然,在尝试从 Python 3 中 pip install psycopg2
时,它仍然使用在使用 Python 2.7 进行安装期间创建的***。所以我不得不使用重建***
sudo -H pip3 install --upgrade --force-reinstall psycopg2
【讨论】:
【参考方案3】:如果您安装了多个 python 版本,那么安装 psycopg 的最佳解决方案是从
下载存档http://initd.org/psycopg/download/
然后通过运行安装(在我的情况下,我想为 python 3.4 安装它)
python3.4 setup.py 构建
sudo python3.4 setup.py install
现在,输入以下命令检查是否已安装:
python3.4
帮助()
模块
它应该在模块列表中显示 psycopg2。
【讨论】:
以上是关于使用 PostgreSQL (psycopg2) 和 Django 运行 Python 3.4 时出错的主要内容,如果未能解决你的问题,请参考以下文章
psycopg2/python 将数据从 postgresql 复制到 Amazon RedShift(postgresql)
SQLAlchemy/psycopg2 到 PostgreSQL 数据库的连接是不是加密
psycopg2 Google Analytics数据到postgresql
使用 PostgreSQL (psycopg2) 和 Django 运行 Python 3.4 时出错