安装的是redis新版本,但导入的时候一直显示是旧版本

使用grep -r "except socket.error, e:" /home/by/PyCharmMiscProject/.venv/lib/python3.12/site-packages/redis/,定位错误文件,并进行问题分析:

  1. pip缓存了错误的包版本

  2. 从非官方源安装了修改过的包

  3. 本地有残留的旧版本文件

解决方法:卸载之前的redis并重新从官网下载

1、开始强制删除原先的文件和缓存,但首先要确保自己所处的环境是正确的:

python 复制代码
# 强制卸载redis包
pip uninstall redis -y

# 手动删除残留文件(重要!)
rm -rf /home/by/PyCharmMiscProject/.venv/lib/python3.12/site-packages/redis*
rm -rf /home/by/PyCharmMiscProject/.venv/lib/python3.12/site-packages/Redis*
# 清理pip缓存
pip cache purge
# 使用官方PyPI源,指定最新版本
pip install redis==7.0.0 --index-url https://pypi.org/simple --no-cache-dir

2、使用以下代码进行验证是否还存在问题:

python 复制代码
#!/usr/bin/env python3
print("Python版本检查...")
import sys

print(f"Python版本: {sys.version}")

print("\n尝试导入redis...")
try:
    import redis

    print(f"✓ 成功导入redis,版本: {redis.__version__}")

    # 测试基本功能
    r = redis.Redis(host='localhost', port=6379, socket_connect_timeout=2)
    try:
        response = r.ping()
        print(f"✓ Redis连接测试: {response}")
    except redis.ConnectionError as e:
        print(f"⚠️  Redis服务未连接: {e}")
        print("请确保Redis服务正在运行: redis-server")

except Exception as e:
    print(f"✗ 导入失败: {type(e).__name__}: {e}")

3、写个测试代码,看下redis能不能连通

python 复制代码
import redis
import json

# 1. 连接到Redis服务器
# 如果Redis有密码,需添加参数 password='yourpassword'
r = redis.Redis(host='localhost', port=6379, db=0)

# 2. 准备一个示例字典
user_info = {
    'id': 1001,
    'name': '张三',
    'age': 28,
    'email': 'zhangsan@example.com'
}

# 3. 将字典序列化为JSON字符串并存储
json_str = json.dumps(user_info, ensure_ascii=False)  # ensure_ascii确保中文正常
r.set('user:1001', json_str)
print("字典已存储。")

# 4. 读取并还原数据
json_data_from_redis = r.get('user:1001')
if json_data_from_redis:
    user_data = json.loads(json_data_from_redis)
    print(f"读取到的数据:{user_data}")
相关推荐
自己的九又四分之三站台26 分钟前
PostgreSQL:万物皆可PostgreSQL的力量
数据库·postgresql
一条大祥脚27 分钟前
25.12.30
数据库·redis·缓存
雨中飘荡的记忆1 小时前
MyBatis SQL执行模块详解
数据库·sql·mybatis
飞Link1 小时前
【MySQL】Linux(CentOS7)下安装MySQL8教程
linux·数据库·mysql
程可爱2 小时前
详解Redis消息队列的三种实现方案
redis
数据库生产实战2 小时前
Oracle的_segment_count和3个event对高并发事务与索引性能的影响分析
数据库·oracle
程序员侠客行2 小时前
Mybatis二级缓存实现详解
java·数据库·后端·架构·mybatis
Tipriest_3 小时前
linux中的文本分接流tee命令介绍
linux·服务器·数据库
爱喝水的鱼丶3 小时前
SAP-ABAP:在SAP世界里与特殊字符“斗智斗勇”:一份来自实战的避坑指南
运维·服务器·数据库·学习·sap·abap·特殊字符
阿拉伯柠檬3 小时前
MySQL内置函数
linux·数据库·mysql·面试