安装的是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}")
相关推荐
廿一夏1 小时前
MySql存储引擎与索引
数据库·sql·mysql
Mahir081 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
曲幽1 小时前
我用了FastApiAdmin后,连夜把踩过的坑都整理出来了
redis·python·postgresql·vue3·fastapi·web·sqlalchemy·admin·fastapiadmin
lzhdim3 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室4 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)4 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU5 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng6 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿7 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-7 小时前
Redis 命令
数据库·redis·缓存