2017-12-30 32 views
7

今から数時間後にこれを試していますが、解決できませんでした。 Windows上でGeoDjangoを設定するにはthisリンクを使用しています。次のエラーメッセージが表示され、何をすべきかわからない。全ての環境変数は、Windowsで設定されていると私はGIS/Gdal/OSGeos Windowsのdjangoでインポートエラーが発生しました

import gdal

は廃止されるのpython端子に成功し

from osgeo import gdal

にインポートすることができています。 PostgreSQLデータベース をpgrouting address_standardizerfuzzystrmatch、 ogr_fdw plpgsqlがpointcloudpointcloud_postgisたPostGISpostgis_sfcgalpostgis_tiger_geocoderのように必要に応じて、私は利用可能なすべての拡張機能を持っていますおよびpostgis_topology

Djangoのプロジェクトの設定:

DATABASES = { 
    'default': { 
     'ENGINE': 'django.contrib.gis.db.backends.postgis', 
     'NAME': 'postgis_24_sample', 
     'USER': 'postgres', 
     'PASSWORD': 'Hello123', 
     'HOST': 'localhost', 
     'PORT': '', 
    } 
} 

GDAL_LIBRARY_PATH = os.getenv('GDAL_LIBRARY_PATH') 
GEOS_LIBRARY_PATH = os.getenv('GEOS_LIBRARY_PATH') 

INSTALLED_APPS = [ 
    ... 
    'django.contrib.postgis', 
    ... 
] 

ERROR:

(easy_geodj) C:\Users\dell\Desktop\easy_geodj\easy_geodj\djlocate>python manage.py runserver 
Unhandled exception in thread started by <function wrapper at 0x066D6330> 
Traceback (most recent call last): 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\utils\autoreload.py", line 227, in wrapper 
    fn(*args, **kwargs) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\core\management\commands\runserver.py", line 117, in inner_run 
    autoreload.raise_last_exception() 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\utils\autoreload.py", line 250, in raise_last_exception 
    six.reraise(*_exception) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\utils\autoreload.py", line 227, in wrapper 
    fn(*args, **kwargs) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\__init__.py", line 27, in setup 
    apps.populate(settings.INSTALLED_APPS) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\apps\registry.py", line 108, in populate 
    app_config.import_models() 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\apps\config.py", line 202, in import_models 
    self.models_module = import_module(models_module_name) 
    File "c:\python27\Lib\importlib\__init__.py", line 37, in import_module 
    __import__(name) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\auth\models.py", line 4, in <module> 
    from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\auth\base_user.py", line 52, in <module> 
    class AbstractBaseUser(models.Model): 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\db\models\base.py", line 124, in __new__ 
    new_class.add_to_class('_meta', Options(meta, app_label)) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\db\models\base.py", line 330, in add_to_class 
    value.contribute_to_class(cls, name) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\db\models\options.py", line 214, in contribute_to_class 
    self.db_table = truncate_name(self.db_table, connection.ops.max_name_length()) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\db\__init__.py", line 33, in __getattr__ 
    return getattr(connections[DEFAULT_DB_ALIAS], item) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\db\utils.py", line 211, in __getitem__ 
    backend = load_backend(db['ENGINE']) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\db\utils.py", line 115, in load_backend 
    return import_module('%s.base' % backend_name) 
    File "c:\python27\Lib\importlib\__init__.py", line 37, in import_module 
    __import__(name) 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\db\backends\postgis\base.py", line 5, in <module> 
    from .features import DatabaseFeatures 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\db\backends\postgis\features.py", line 1, in <module> 
    from django.contrib.gis.db.backends.base.features import BaseSpatialFeatures 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\db\backends\base\features.py", line 4, in <module> 
    from django.contrib.gis.db.models import aggregates 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\db\models\__init__.py", line 3, in <module> 
    from django.contrib.gis.db.models.aggregates import * # NOQA 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\db\models\aggregates.py", line 1, in <module> 
    from django.contrib.gis.db.models.fields import ExtentField 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\db\models\fields.py", line 3, in <module> 
    from django.contrib.gis import forms, gdal 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\forms\__init__.py", line 3, in <module> 
    from .fields import ( # NOQA 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\forms\fields.py", line 4, in <module> 
    from django.contrib.gis.geos import GEOSException, GEOSGeometry 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\geos\__init__.py", line 5, in <module> 
    from .collections import ( # NOQA 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\geos\collections.py", line 11, in <module> 
    from django.contrib.gis.geos.geometry import GEOSGeometry, LinearGeometryMixin 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\geos\geometry.py", line 11, in <module> 
    from django.contrib.gis import gdal 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\gdal\__init__.py", line 43, in <module> 
    from django.contrib.gis.gdal.driver import Driver # NOQA 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\gdal\driver.py", line 5, in <module> 
    from django.contrib.gis.gdal.prototypes import ds as vcapi, raster as rcapi 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\gdal\prototypes\ds.py", line 9, in <module> 
    from django.contrib.gis.gdal.libgdal import GDAL_VERSION, lgdal 
    File "C:\Users\dell\Desktop\easy_geodj\lib\site-packages\django\contrib\gis\gdal\libgdal.py", line 48, in <module> 
    lgdal = CDLL(lib_path) 
    File "c:\python27\Lib\ctypes\__init__.py", line 366, in __init__ 
    self._handle = _dlopen(self._name, mode) 
WindowsError: [Error 126] The specified module could not be found 
+0

'GDAL_LIBRARY_PATH'を設定しましたか?あなたのWindowsパス上のGDAL DLLはありますか? –

+0

はいそれを追加しました –

+0

'c:\ python27 \ Lib \ ctypes \ __ init __。py'を開き、 'self._handle = _dlopen(self._name、mode)の前に' print(self._name) 'と結果を投稿します。 –

答えて

3

GISの依存関係は、特にWindowsでは正しく取得するのが難しいです。あなたがこのOSに固執したいなら、私はOsGeo4Wを続けて使うことを勧めます。私のために働いた

手順は次のとおりです。

あなたがインストールしたものをGISパッケージのすべてのディストリビューションをアンインストールし、慎重にOSGeo4W installation instructionsに従っていることを確認してください。 ApacheとMapServerはデフォルトでインストールされるようにチェックされていますが、必要がない場合はチェックを外すことができます。

GEOS_LIBRARY_PATH = 'C:\\OSGeo4W64\\bin\\geos_c.dll' 
GDAL_LIBRARY_PATH = 'C:\\OSGeo4W64\\bin\\gdal201.dll' 

注1:(私が覚えている)パスは、それらがデフォルトですあなたはOSGeo4Wをインストールした場所によって異なりますが、あなたがこのように見えるためにあなたのsettings.pyを変更することができるよりも

注2:あなたは32ビット版をダウンロードしてインストールした場合、あなたのパスではなく、次のようになります。

GEOS_LIBRARY_PATH = 'C:\\OSGeo4W\\bin\\geos_c.dll' 
GDAL_LIBRARY_PATH = 'C:\\OSGeo4W\\bin\\gdal201.dll' 

を、私は同様のスタックを使用してプロジェクトに取り組んで、それは非常に簡単だったと感じてきましたLinux(Ubuntu、特に)上で物事を設定する。とにかくLinuxマシンでホストされることになってしまうのであれば、私はLinux開発環境に向かうことをお勧めします。Ubuntuで

、たとえば、あなただけ行うことができます。また

$ sudo apt-get install binutils libproj-dev gdal-bin 

GeoDjango official docsはにいくつかの良い情報を持っています。

3

私は手動でインストールを自分で処理するための試みをすべて無視し、anaconda環境を使用します。インストールするにはGISの依存関係が気まぐれに変わり、anacondaは多数の粗いエッジを平滑化しました。

関連する問題