2012-04-24 39 views
5

Mam poważne problemy z konfigurowaniem przestrzennej bazy danych i synchronizowaniem jej z GeoDjango. Udało mi się skonfigurować baza danych przestrzennych zgodnie z dokumentacją geodjango i stworzyć aplikację django ale gdy uruchamiamNie można synchronizować w aplikacji GeoDjango

python manage.py sqlall world

jestem coraz to

Traceback (most recent call last): 
    File "manage.py", line 10, in <module> 
    execute_from_command_line(sys.argv) 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 443, in execute_from_command_line 
    utility.execute() 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 382, in execute 
    self.fetch_command(subcommand).run_from_argv(self.argv) 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 261, in fetch_command 
    klass = load_command_class(app_name, subcommand) 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 69, in load_command_class 
    module = import_module('%s.management.commands.%s' % (app_name, name)) 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/utils/importlib.py", line 35, in import_module 
    __import__(name) 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/core/management/commands/sqlall.py", line 4, in <module> 
    from django.core.management.sql import sql_all 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/core/management/sql.py", line 6, in <module> 
    from django.db import models 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/db/__init__.py", line 40, in <module> 
    backend = load_backend(connection.settings_dict['ENGINE']) 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/db/__init__.py", line 34, in __getattr__ 
    return getattr(connections[DEFAULT_DB_ALIAS], item) 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/db/utils.py", line 92, in __getitem__ 
    backend = load_backend(db['ENGINE']) 
    File "/home/smaranh/django-env/local/lib/python2.7/site-packages/django/db/utils.py", line 44, in load_backend 
    raise ImproperlyConfigured(error_msg) 
django.core.exceptions.ImproperlyConfigured: 'django.contrib.gis.db.backends.postgis' isn't an available database backend. 
Try using django.db.backends.XXX, where XXX is one of: 
    'dummy', 'mysql', 'oracle', 'postgresql_psycopg2', 'sqlite3' 
Error was: No module named psycopg2.extensions 

Jestem zmęczony i naprawdę nie wiem, co robić? Proszę o pomoc

EDIT

Ok znalazłem ten link jaki rodzaj mówi mi, co poszło źle. Teraz, kiedy dostanie się do python od \ domu, a ja wykonać import psycopg2 nie daje mi żadnych ImportError ale kiedy jestem wewnątrz wirtualnego env, otrzymuję ImportError

(django-env)[email protected]:~/geodjango$ python 
Python 2.7.2+ (default, Oct 4 2011, 20:06:09) 
[GCC 4.6.1] on linux2 
Type "help", "copyright", "credits" or "license" for more information. 
>>> import psycopg2 
Traceback (most recent call last): 
    File "<stdin>", line 1, in <module> 
ImportError: No module named psycopg2 

teraz link kieruje mnie w jaki sposób dopisz ścieżkę, ale naprawdę nie rozumiem tego procesu, ponieważ jestem nowy i nie chcę go dalej łamać. Więc może ktoś pls poprowadzi mnie krok po kroku, jak dołączyć sys.path?

+0

można dodawać wartość BAZY na swoim settings.py? – dannyroa

+0

'DATABASES = { " default ": { " ENGINE ": 'django.contrib.gis.db.backends.postgis', # Dodaj 'postgresql_psycopg2', 'mysql', 'sqlite3' lub 'oracle'. 'NAME': 'geodjango', # Lub ścieżka do pliku bazy danych, jeśli używasz sqlite3. "UŻYTKOWNIK": "smaranh", # Nie używany z sqlite3. 'HASŁO': '', # Nie używane z sqlite3. 'HOST': '', # Ustaw na pusty ciąg dla localhost. Nie używany z sqlite3. 'PORT': '', # Ustaw domyślnie na pusty łańcuch. Nie używany z sqlite3. } } ' – Sam007

+0

@dannyroa Wydaje mi się, że znalazłem odpowiedź, właśnie zredagowałem mój post, czy możesz pomóc mi go zrozumieć i dać mi znać, jak powinienem kontynuować? – Sam007

Odpowiedz

18

Jeśli używasz virtualenv trzeba zainstalować psycopg2 wewnątrz środowiska, coś jak:

pip install psycopg2 

ale trzeba zainstalować niektórych pakietów z mieszkaniem wcześniej:

sudo apt-get install python-dev postgresql-server-dev-all 
+0

, więc powinienem najpierw zainstalować 'sudo apt-get zainstaluj Pythona-dev Postgresql-server-dev-all' , a następnie zainstaluj 'pip install psycopg2' – Sam007

+0

Bardzo dziękuję @ diegueus9, to była naprawdę wielka pomoc – Sam007

+0

@ Sam007 moja przyjemność – diegueus9

Powiązane problemy