我正在尝试让Django的SQLite3接受空间查询。 This tutorial建议我将其添加到设置中:
SPATIALITE_LIBRARY_PATH = 'mod_spatialite'
产生此错误:
django.core.exceptions.ImproperlyConfigured:无法加载 SpatiaLite库扩展名“mod_spatialite”因为:指定的 无法找到模块。
我也试过这样做:
SPATIALITE_LIBRARY_PATH = r'C:\\Program Files (x86)\\Spatialite\\mod_spatialite-4.3.0a-win-x86\\mod_spatialite-4.3.0a-win-x86\\mod_spatialite.dll'
如果我不添加此变量,则在迁移时会收到此错误:
django.core.exceptions.ImproperlyConfigured:无法找到 SpatiaLite图书馆。确保它在您的库路径中,或设置 您设置中的SPATIALITE_LIBRARY_PATH。
谢谢..
答案 0 :(得分:3)
有趣的是,5天后,我遇到了同样的问题。经过一番探索后,我开始工作了:
集
SPATIALITE_LIBRARY_PATH = 'mod_spatialite'
并将mod_spatialite-x.x.x-win-x86.7z中的所有DLL文件解压缩到Python安装目录。 dll显然需要与python.exe在同一个文件夹中。另外我想根据你的python安装,mod_spatialite包需要32/64位。如果你遗漏了一些dll,你会得到同样的错误“找不到指定的模块”,不管丢失了什么dll文件,所以它有点误导。
从http://www.gaia-gis.it/gaia-sins/
下载我使用mod_spatialite稳定版本4.3.0a x86和Python 3.5.2 32位。
关于同一问题的其他线索以及各种答案:
答案 1 :(得分:0)
这是如何在Python 3的virtualenv中安装SpatiaLite(几乎):
mod_spatialite-[version]-win-x86.7z
Scripts
文件夹中。 这部分我不喜欢但我没有触及主要的Python3安装就找不到可行的解决方案。
c:\Python35\DLLs\sqlite3.dll
cyqlite
uznip sqlite3.dll
文件到c:\Python35\DLLs\
答案 2 :(得分:0)
在Ubuntu18.04上,
添加SPATIALITE_LIBRARY_PATH = 'mod_spatialite.so'
安装了libsqlite3-mod-spatialite
的计算机对我有用。
注意:答案是mod_spatialite
,而对我来说mod_spatialite.so
有用。
答案 3 :(得分:0)
尝试在AWS Elastic Beanstalk上部署GeoDjango时遇到了这个问题。原来,我需要将SPATIALITE_LIBRARY_PATH = 'mod_spatialite.so'
设置为SPATIALITE_LIBRARY_PATH = 'libspatialite.so'
(从我的sudo yum install libspatialite
运行sudo yum install libspatialite-devel
和.ebextensions
之后,安装在/user/lib64/libspatialite.so中)。
答案 4 :(得分:-1)
如何在WINDOWS操作系统中激活正确的DJANGO环境中的正确空间,如7,8,10
我希望我的答案能够让我的开发人员朋友安全地使用django默认提供的Sqlite来管理他们的地理数据,这是一个扩展,默认情况下也是在python(3或+)中提供的。我从一个预先配置的虚拟环境开始。首先要做的是下载两个zip:sqlite-dll-win32-x86-[version].zip和mod_spatialite-[version]-win-x86.7z并在同一目录中解压缩(如果有任何冲突,则覆盖)
将所有以前解压缩的文件复制到您的目录中并将其粘贴到虚拟环境的Scripts目录中
如有必要,请重启您的电脑,停用并重新激活您的虚拟环境和代码......