2012-04-24 15 views
5

Sto riscontrando un problema reale nell'impostazione del database spaziale e nella sincronizzazione con GeoDjango. Sono stato in grado di impostare il database spaziale come per la documentazione geodjango e creare un app Django, ma quando ho eseguitoImpossibile sincronizzare l'app GeoDjango

python manage.py sqlall world

sto ottenendo questo,

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 

Sono stanco e davvero non sicuri Cosa fare? Si prega di aiutare

EDIT

Ok ho trovato questo link che tipo di mi dice che cosa è andato storto. Ora, quando ottengo nella python da \ casa, e io eseguo import psycopg2 che non mi dà alcun ImportError ma quando sono all'interno della ENV virtuale, ho l'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 

Ora il link mi guida su come aggiungo il percorso ma non sto veramente capendo il processo da quando sono nuovo e non voglio rovinare ulteriormente. Quindi qualcuno mi può guidare passo dopo passo come aggiungere lo sys.path ??

+0

potete inserire il valore DATABASE sul tuo settings.py? – dannyroa

+0

'DATABASES = { 'default': { 'ENGINE': 'django.contrib.gis.db.backends.postgis', # Aggiungi 'postgresql_psycopg2', 'mysql', 'sqlite3' o 'oracle'. 'NOME': 'geodjango', # O percorso al file del database se si utilizza sqlite3. 'USER': 'smaranh', # Non utilizzato con sqlite3. 'PASSWORD': '', # Non utilizzato con sqlite3. 'HOST': '', # Imposta la stringa vuota per localhost. Non utilizzato con sqlite3. 'PORT': '', # Imposta su stringa vuota per impostazione predefinita. Non utilizzato con sqlite3. } } ' – Sam007

+0

@dannyroa Penso di aver trovato la risposta, ho appena modificato il mio post, potresti aiutarmi a capirlo e fammi sapere come dovrei procedere ulteriormente? – Sam007

risposta

18

Se si utilizza virtualenv è necessario installare psycopg2 all'interno dell'ambiente, qualcosa come:

pip install psycopg2 

ma è necessario installare alcuni pacchetti con apt prima che:

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

quindi dovrei prima installare 'sudo apt-get installa python-dev postgresql-server-dev-all' e quindi installa 'pip installa psycopg2' – Sam007

+0

Grazie mille @ diegueus9, che è stato davvero di grande aiuto – Sam007

+0

@ Sam007 piacere mio – diegueus9