Путь к Django в Google App Engine - PullRequest
       2

Путь к Django в Google App Engine

0 голосов
/ 20 декабря 2010

Я совершенно не понимаю эту ошибку. Я использую django-nonrel, загрузите его в свое приложение с помощью manage.py. И иногда У меня есть это:

<type 'exceptions.AttributeError'>: 'Settings' object has no attribute 'DATABASE_ROUTERS'
Traceback (most recent call last):
File "/base/data/home/apps/appid/3.347077242893060339/execute.py", line 2, in <module>
  from djapp import queue_controller
File "/base/data/home/apps/appid/3.347077242893060339/djapp/queue_controller.py", line 5, in <module>
  from djapp.models import Operation
File "/base/data/home/apps/appid/3.347077242893060339/djapp/models.py", line 3, in <module>
  from django.db import models
File "/base/data/home/apps/appid/3.347077242893060339/django/db/__init__.py", line 66, in <module>
  router = ConnectionRouter(settings.DATABASE_ROUTERS)
File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/conf/__init__.py", line 32, in __getattr__
  return getattr(self._target, name)

или

<type 'exceptions.ImportError'>: No module named files.uploadhandler  
Traceback (most recent call last):
File "/base/data/home/apps/appid/3.347067228745038183/djangoappengine/main/main.py", line 28, in <module>
  from django.core.handlers.wsgi import WSGIHandler
File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/core/handlers/wsgi.py", line 1, in <module>
  from django.core.handlers.base import BaseHandler
File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/core/handlers/base.py", line 3, in <module>
  from django import http
File "/base/data/home/apps/appid/3.347067228745038183/django/http/__init__.py", line 28, in <module>
  from django.http.multipartparser import MultiPartParser
File "/base/data/home/apps/appid/3.347067228745038183/django/http/multipartparser.py", line 14, in <module>
  from django.core.files.uploadhandler import StopUpload, SkipFile, StopFutureHandlers

Что не так с путем? Почему это происходит? Сначала это путь "/base/data/home/apps/app-id/3.347046818251769742/django/", а затем "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/".
И как избежать этой ошибки?

Я проверил sys.path, несколько раз загрузил новый django, удалил все ненужные файлы, я потерян: (

sys.path = ['/base/data/home/apps/appid/3.347077364008022180', 
'/base/data/home/apps/appid/3.347077364008022180/djangoappengine/lib', 
'/base/python_runtime/python_dist/lib/python25.zip', 
'/base/python_runtime/python_dist/lib/python2.5/', 
'/base/python_runtime/python_dist/lib/python2.5/plat-linux2', 
'/base/python_runtime/python_dist/lib/python2.5/lib-tk',
'/base/python_runtime/python_dist/lib/python2.5/lib-dynload',
'/base/python_runtime/python_lib/versions/1',
'/base/data/home/apps/appid/3.347077364008022180/']

1 Ответ

0 голосов
/ 20 декабря 2010

Полагаю, что db/__init__.py делает что-то вроде from django.conf import Settings, и по какой-то причине ему иногда дается системная версия Django, а не ваша собственная.

Вы можете попробовать изменить ее на относительнуюimport, например from ..conf import Settings, что должно означать, что он использует версию в том же пакете, что и сам.Это работает с Python 2.5, который использует Appengine.

...