为什么python3调用python2库?

2024-09-29 19:35:44 发布

您现在位置:Python中文网/ 问答频道 /正文

当尝试访问使用django创建的网站时,apache2生成以下错误。从下面的错误中可以看到,psycopg2未能加载。这可能是因为它试图使用python2库而不是python3。所以我想知道这是怎么发生的,有什么解决办法。谢谢

mod_wsgi (pid=2603): Target WSGI script '/var/www/iMARS/iMARS/wsgi.py' cannot be loaded as Python module., referer: 
mod_wsgi (pid=2603): Exception occurred processing WSGI script '/var/www/iMARS/iMARS/wsgi.py'., referer: 
 Traceback (most recent call last):, referer: 
   File "/var/www/iMARS/iMARS/wsgi.py", line 16, in <module>, referer: 
     application = get_wsgi_application(), referer: http://mana.smcnus.org/
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/core/wsgi.py", line 13, in get_wsgi_application, referer: 
     django.setup(), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/__init__.py", line 18, in setup, referer: 
     apps.populate(settings.INSTALLED_APPS), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/apps/registry.py", line 108, in populate, referer: 
     app_config.import_models(all_models), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/apps/config.py", line 202, in import_models, referer: 
     self.models_module = import_module(models_module_name), referer: 
   File "/usr/lib64/python2.7/importlib/__init__.py", line 37, in import_module, referer: 
     __import__(name), referer: 
   File "/var/www/iMARS/core/models.py", line 2, in <module>, referer: 
     from django.contrib.auth.models import AbstractBaseUser, referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/contrib/auth/models.py", line 4, in <module>, referer: 
     from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager, referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/contr ib/auth/base_user.py", line 49, in <module>, referer: 
     class AbstractBaseUser(models.Model):, referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/db/models/base.py", line 108, in __new__, referer: 
     new_class.add_to_class('_meta', Options(meta, app_label)), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/db/models/base.py", line 299, in add_to_class, referer: 
     value.contribute_to_class(cls, name), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/db/models/options.py", line 263, in contribute_to_class, referer: 
     self.db_table = truncate_name(self.db_table, connection.ops.max_name_length()), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/db/__init__.py", line 36, in __getattr__, referer: 
     return getattr(connections[DEFAULT_DB_ALIAS], item), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/db/utils.py", line 212, in __getitem__, referer: 
     backend = load_backend(db['ENGINE']), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/db/utils.py", line 116, in load_backend, referer: 
     return import_module('%s.base' % backend_name), referer: 
   File "/usr/lib64/python2.7/importlib/__init__.py", line 37, in import_module, referer: 
     __import__(name), referer: 
   File "/opt/virtualenvs/iMARS/lib/python3.4/site-packages/django/db/backends/postgresql/base.py", line 24, in <module>, referer: 
     raise ImproperlyConfigured("Error loading psycopg2 module: %s" % e), referer: 
 ImproperlyConfigured: Error loading psycopg2 module: No module named _psycopg

Tags: djangoinpyimportmodelslibpackagesline
1条回答
网友
1楼 · 发布于 2024-09-29 19:35:44

在centos7和apache上,mysqlclient也遇到了类似的问题,默认mod_wsgi是python2的。在

首先尝试检查是否可以从shell运行Django应用程序:

source /opt/virtualenvs/iMARS/bin/activate
python manage.py shell

如果这是可行的,问题是mod_wsgi(在CentOS上)可以这样更新:

^{pr2}$

这个问题提供了Ubuntu的解决方案:Django MySQLdb issue on apache2

相关问题 更多 >

    热门问题