私は前にこれを十数回やったことがありますが、今回は何かがうまくいきません。
ドキュメントに従って:
https://docs.djangoproject.com/en/1.11/ref/contrib/gis/install/#windows
私はWindowsマシンでGeoDjangoをセットアップしようとしています(これは、paperspace.comでセットアップされた仮想Windows 10です)。 PATH設定に問題があるようですが、何なのかわかりません。手順で強調表示されているコマンドを実行しました。 PATH変数を確認しましたが、すべて問題ないようです。私はそれらにOSGeo4Winの32ビットバージョンと64ビットバージョンの両方を指すように試みました。とにかく、毎回次の出力が表示されます。
C:\Python\lib\site-packages\floppyforms\__init__.py:21: UserWarning: Unable to import floppyforms.gis, geometry widgets not available
"Unable to import floppyforms.gis, geometry widgets not available")
Traceback (most recent call last):
File "manage.py", line 10, in <module>
execute_from_command_line(sys.argv)
File "C:\Python\lib\site-packages\Django\core\management\__init__.py", line 363, in execute_from_command_line
utility.execute()
File "C:\Python\lib\site-packages\Django\core\management\__init__.py", line 337, in execute
Django.setup()
File "C:\Python\lib\site-packages\Django\__init__.py", line 27, in setup
apps.populate(settings.INSTALLED_APPS)
File "C:\Python\lib\site-packages\Django\apps\registry.py", line 108, in populate
app_config.import_models()
File "C:\Python\lib\site-packages\Django\apps\config.py", line 202, in import_models
self.models_module = import_module(models_module_name)
File "C:\Python\lib\importlib\__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 978, in _gcd_import
File "<frozen importlib._bootstrap>", line 961, in _find_and_load
File "<frozen importlib._bootstrap>", line 950, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 655, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 678, in exec_module
File "<frozen importlib._bootstrap>", line 205, in _call_with_frames_removed
File "C:\Python\lib\site-packages\Django\contrib\auth\models.py", line 4, in <module>
from Django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
File "C:\Python\lib\site-packages\Django\contrib\auth\base_user.py", line 52, in <module>
class AbstractBaseUser(models.Model):
File "C:\Python\lib\site-packages\Django\db\models\base.py", line 124, in __new__
new_class.add_to_class('_meta', Options(meta, app_label))
File "C:\Python\lib\site-packages\Django\db\models\base.py", line 330, in add_to_class
value.contribute_to_class(cls, name)
File "C:\Python\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:\Python\lib\site-packages\Django\db\__init__.py", line 33, in __getattr__
return getattr(connections[DEFAULT_DB_ALIAS], item)
File "C:\Python\lib\site-packages\Django\db\utils.py", line 211, in __getitem__
backend = load_backend(db['ENGINE'])
File "C:\Python\lib\site-packages\Django\db\utils.py", line 115, in load_backend
return import_module('%s.base' % backend_name)
File "C:\Python\lib\importlib\__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "C:\Python\lib\site-packages\Django\contrib\gis\db\backends\postgis\base.py", line 5, in <module>
from .features import DatabaseFeatures
File "C:\Python\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:\Python\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:\Python\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:\Python\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:\Python\lib\site-packages\Django\contrib\gis\db\models\fields.py", line 3, in <module>
from Django.contrib.gis import forms, gdal
File "C:\Python\lib\site-packages\Django\contrib\gis\forms\__init__.py", line 3, in <module>
from .fields import ( # NOQA
File "C:\Python\lib\site-packages\Django\contrib\gis\forms\fields.py", line 4, in <module>
from Django.contrib.gis.geos import GEOSException, GEOSGeometry
File "C:\Python\lib\site-packages\Django\contrib\gis\geos\__init__.py", line 5, in <module>
from .collections import ( # NOQA
File "C:\Python\lib\site-packages\Django\contrib\gis\geos\collections.py", line 11, in <module>
from Django.contrib.gis.geos.geometry import GEOSGeometry, LinearGeometryMixin
File "C:\Python\lib\site-packages\Django\contrib\gis\geos\geometry.py", line 11, in <module>
from Django.contrib.gis import gdal
File "C:\Python\lib\site-packages\Django\contrib\gis\gdal\__init__.py", line 28, in <module>
from Django.contrib.gis.gdal.datasource import DataSource
File "C:\Python\lib\site-packages\Django\contrib\gis\gdal\datasource.py", line 39, in <module>
from Django.contrib.gis.gdal.driver import Driver
File "C:\Python\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:\Python\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:\Python\lib\site-packages\Django\contrib\gis\gdal\libgdal.py", line 44, in <module>
'GDAL_LIBRARY_PATH in your settings.' % '", "'.join(lib_names)
Django.contrib.gis.gdal.error.GDALException: Could not find the GDAL library (tried "gdal111", "gdal110", "gdal19", "gdal18", "gdal17"). Try setting GDAL_LIBRARY_PATH in your settings.
誰かアイデアはありますか?
更新:店に行って新しいラップトップを購入しましたが、それでも同じ問題が発生しています。一部のGeoDjango依存関係のバージョン管理の問題ですか?どうしたらいいのか途方に暮れていますが、それは私にとって緊急事態のようなものです。
問題は DjangoとGDALの間のバージョンの不一致 です。Djangoは正しいファイル名を検索していません(_gdal202.dll
_(私の場合)。
これを修正するには、26行目の次のファイルにstr('gdal202')
を追加する必要がありました。
_(Python Root)\Lib\site-packages\Django\contrib\gis\gdal\libgdal.py
_
仮想環境で作業している場合、_Python Root
_は実際にはどこにあるかに注意してください:_Users\YourName\Envs\project
_
この問題が再発する場合は、_C:\OSGeo4W\bin
_ディレクトリを調べて、どの_gdalxxx.dll
_ Djangoで検索する必要があるか)を確認できます。
さらに、PythonおよびOSGeo4Winの32ビットバージョンを使用していることを確認してください。それ以外の場合は、同じエラーが発生する可能性があります。
追加
GDAL_LIBRARY_PATH = r'C:\OSGeo4W64\bin\gdal202'
Django設定が私のために働いた
以前のコメントに加えて。 [WinError 127]が指定されている可能性があります指定されたプロシージャが見つかりませんでした。
これは、システムに複数のsqlite3.dllがあるために表示されます。パスが最初にヒットした場合、gdal202の競合が発生します。
作業ディレクトリの変更も追加することで、adam starrhの回答を拡張できます。
#Set working directory to actual working directoy of gdal
#This is required to prevent any conflicts with older SQLITE versions,
#f.e. in python path
#Prevents error in GDAL 202
#BASE_WORKINGDIRECTORY to change it back later if you need to
BASE_WORKDIRECTORY = os.getcwd()
os.chdir(os.path.dirname(lib_path))
# This loads the GDAL/OGR C library
lgdal = CDLL(lib_path)
Djangoチュートリアルを使用し、OSGeo4Wを介してGDALをインストールする場合、Windows環境を変更するときに、適切なPythonおよびOSGeo4Wバージョンを定義していることを確認してください。
たとえば、64ビットOSGeo4Wをインストールする場合、環境パスを設定する必要があります。
set OSGEO4W_ROOT=C:\OSGeo4W64
Python 3.5.2の場合:
set PYTHON_ROOT=C:\Python36
Python virtualenvへのインストールをシステムPythonと混同しないように注意してください。
インストールのみDjango after環境を適切に変更しました。
私にとって、この問題はWindows
でパスをosgeo
pythonパッケージに環境変数(C:\ Python36\Lib\site -packages\osgeo)。これを実行した後、Djangoがgdal202.dll
ファイル。
解決:
pip install GDAL
_、動作しない場合はホイールからインストールします: https://www.lfd.uci.edu/~gohlke/pythonlibs/#gdala)仮想環境を使用する場合は、このコードをsettings.pyに追加するだけです:_os.environ["PATH"] += os.pathsep + BASE_DIR + '\\venv\\Lib\\site-packages\\osgeo'
_
b)または、次のコードを追加します。
from distutils.sysconfig import get_python_lib os.environ["PATH"] += os.pathsep + get_python_lib() + '\\osgeo'
移行を行うと、次のような問題が発生します ここに画像の説明を入力してください
多分dll(gdal202.dll)libは動作しません。 GDALライブラリ全体をGDAL-whl-packageに置き換えます https://download.lfd.uci.edu/pythonlibs/r5uhg2lo/GDAL-2.3.2-cp36-cp36m-win_AMD64.whl =このwhlパッケージをダウンロードし、GDAL-2.3.2-cp36-cp36m-win_AMD64.whl.Zipに名前を変更 ここに画像の説明を入力 osgeoフォルダーを1か所に抽出(D:\ ProgramData\osgeo) GDAL_DATA PROJ_LIBとそのサブフォルダーへのパスを変更します
つまり、Windows環境を
set OSGEO4W_ROOT=C:\OSGeo4W
set PYTHON_ROOT=C:\Python3X
set GDAL_DATA=%OSGEO4W_ROOT%\share\gdal
set PROJ_LIB=%OSGEO4W_ROOT%\share\proj
set PATH=%PATH%;%PYTHON_ROOT%;%OSGEO4W_ROOT%\bin
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v Path /t REG_EXPAND_SZ /f /d "%PATH%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v GDAL_DATA /t REG_EXPAND_SZ /f /d "%GDAL_DATA%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v PROJ_LIB /t REG_EXPAND_SZ /f /d "%PROJ_LIB%"
に
set OSGEO4W_ROOT=D:\ProgramData\osgeo
set PYTHON_ROOT=C:\Python3X
set GDAL_DATA=%OSGEO4W_ROOT%\data\gdal
set PROJ_LIB=%OSGEO4W_ROOT%\data\proj
set PATH=%PATH%;%PYTHON_ROOT%;%OSGEO4W_ROOT%\bin
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v Path /t REG_EXPAND_SZ /f /d "%PATH%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v GDAL_DATA /t REG_EXPAND_SZ /f /d "%GDAL_DATA%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v PROJ_LIB /t REG_EXPAND_SZ /f /d "%PROJ_LIB%"
PS:「D:\ ProgramData\osgeo\gdal203.dll」を「D:\ ProgramData\osgeo\gdal202.dll」に名前変更することを忘れないでください