Python:pysqlite库不支持C扩展加载

时间:2012-06-19 02:24:07

标签: python django sqlite postgis spatialite

我正在尝试让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并启用扩展加载。

帮助?

2 个答案:

答案 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

相关问题