Python3不支持sqlite3的解决方法

先贴报错:

python 复制代码
>>> import sqlite3
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/local/lib/python3.10/sqlite3/__init__.py", line 57, in <module>
    from sqlite3.dbapi2 import *
  File "/usr/local/lib/python3.10/sqlite3/dbapi2.py", line 27, in <module>
    from _sqlite3 import *
ModuleNotFoundError: No module named '_sqlite3'

在网上查了一下,居然要我先安装sqlite3,再重新编译安装python,真无语了,奈何开发环境是Windows,话不多说,连上Centos开搞吧:

一、安装sqlite3的包

python 复制代码
yum install -y sqlite-devel

我这里把各个服务器都装上了,准备全都搞一遍,免得后面麻烦,请告诉我还是什么是不支持的吧,真想全都先装了再编译,其他都还好,主要是费时间。

二、重新编译python

看看_sqlite3.so这个动态库在什么地方,等会儿编译的时候需要链接。

复制代码
[root@he Python-3.10.11]# find / -name _sqlite3.so
/usr/lib64/python2.7/lib-dynload/_sqlite3.so

看看python的系统路径都在什么地方:

python 复制代码
>>> import sys
>>> print(sys.path)     
['', '/usr/local/lib/python3.10/site-packages', '/var/local/Python-3.10.11', '/usr/local/lib/python310.zip', '/usr/local/lib/python3.10', '/usr/local/lib/python3.10/lib-dynload']

将这个动态库拷贝到python的动态库中(干嘛要去掉呢)
cp /usr/lib64/python2.7/lib-dynload/_sqlite3.so /usr/local/lib/python3.10/lib-dynload/

这样把sqlite3的动态库拷贝到python的系统环境变量下的动态库路径中,后面编译的时候就省事了。

进入到python安装包的目录,然后就开始编译吧,等编译完成

python 复制代码
make clean
./configure

make && make install

ok,编译好了,再import一下sqlite3

复制代码
>>> import sqlite3
>>> 

没有报错,那就是成功了。

相关推荐
通域3 分钟前
Mac (m1) Java 加载本地C共享库函数 .dylib 函数 Unable to load library ‘liblicense‘
java·python·macos
weixin_4432906911 分钟前
【脚本系列】如何使用 Python 脚本对同一文件夹中表头相同的 Excel 文件进行合并
开发语言·python·excel
暮色驶过苍茫22 分钟前
H2 与高斯数据库兼容性解决方案:虚拟表与类型处理
数据库·oracle
zm32 分钟前
多客户端-服务器(select,poll)
网络·数据库
chao_78937 分钟前
动态规划题解——乘积最大子数组【LeetCode】
python·算法·leetcode·动态规划
倔强青铜三38 分钟前
苦练Python第20天:Python官方钦定的代码风格指南
人工智能·python·面试
倔强青铜三1 小时前
苦练Python第19天:断言与自定义异常
人工智能·python·面试
荷蒲1 小时前
【小白量化智能体】应用5:编写通达信股票交易指标及生成QMT自动交易Python策略程序
开发语言·python
大模型真好玩1 小时前
深入浅出LangChain AI Agent智能体开发教程(一)—认识LangChain&LangGraph
人工智能·python·mcp
医工交叉实验工坊1 小时前
R 语言绘制 10 种精美火山图:转录组差异基因可视化
python·信息可视化·r语言