使用 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(忘记指定),但是安装 psycopg2pip3 确实成功了,错过了。如果我不使用 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 时出错

使用 psycopg2 copy_expert 从 postgreSQL 表中更快地读取数据

SQLAlchemy,Psycopg2和Postgresql COPY