我正在尝试让Spatialite与我的django应用程序一起使用,但是,我已经碰到了以下一面墙:
raise ImproperlyConfigured('The pysqlite library does not support C extension loading. '
django.core.exceptions.ImproperlyConfigured: The pysqlite library does not support C extension loading. Both SQLite and pysqlite must be configured to allow the loading of extensions to use SpatiaLite.
make: *** [syncdb] Error 1
使用ubuntu 12.04,我在同一个用户和sudo中使用pip
安装了pysqlite。我也尝试过编译pysqlite并启用扩展加载。
帮助?
答案 0 :(得分:4)
pysqlite的默认设置是在没有扩展加载支持的情况下构建。所以只是重建无济于事。您需要更改设置(在setup.cfg中)。
所以我建议下载为tarball,然后查看setup.cfg:
[build_ext]
#define=
#include_dirs=/usr/local/include
#library_dirs=/usr/local/lib
libraries=sqlite3
define=SQLITE_OMIT_LOAD_EXTENSION
最后一行是问题所在。最简单的方法就是将其评论出来(在行的开头添加一个#),所以它看起来像:
[build_ext]
#define=
#include_dirs=/usr/local/include
#library_dirs=/usr/local/lib
libraries=sqlite3
# define=SQLITE_OMIT_LOAD_EXTENSION
然后根据tarball中的说明重建(参见doc / install-source.txt)
答案 1 :(得分:0)
此处提出的解决方案似乎适用于较旧的系统/ Python2。对于较新版本的Python(例如3.8版),sqlite作为标准库的一部分提供,因此有必要使用适当配置的sqlite库来构建Python。
例如,在使用homebrew和pyenv的MacOS上(假设满足Python依赖性,并且通过启用扩展加载的homebrew安装了sqlite):
PYTHON_CONFIGURE_OPTS="--enable-loadable-sqlite-extensions --enable-optimizations --with-openssl=\$(brew --prefix openssl)" \
LDFLAGS="-L/usr/local/opt/sqlite/lib" \
CPPFLAGS="-I/usr/local/opt/sqlite/include" \
pyenv install 3.8.2
有关详细的解决方案,请选中here