Python连接Redis数据库进行增删改查(附带常用方法)
off999 2024-11-04 13:16 43 浏览 0 评论
"""Redis数据类型:
1. <set key value>
类型 : String(字符串)
简介: 二进制安全
特性 : 可以包含任何数据,比如jpg图片或者序列化的对象,一个键最大能存储512M
场景: /
2. <hset major_key key value>
类型 : Hash(字典)
简介: 键值对集合,即编程语言中的Map类型
特性 : 适合存储对象,并且可以像数据库中update一个属性一样只修改某一项属性值(Memcached中需要取出整个字符串反序列化成对象修改完再序列化存回去)
场景: 存储、读取、修改用户属性
3. <头部:lpush key value1 value2 ... 末尾:rpush key value1 value2 ...> 可添加一个或多个值
类型 : List(列表)
简介: 链表(双向链表)
特性 : 增删快,提供了操作某一段元素的API
场景: 1.最新消息排行等功能(比如朋友圈的时间线) 2.消息队列
4. <sadd key member1 member2 ...> 可添加一个或多个值
类型 : Set(集合)
简介: 哈希表实现,元素不重复
特性 : 1.添加、删除,查找的复杂度都是O(1) 2.为集合提供了求交集、并集、差集等操作
场景: 1.共同好友 2.利用唯一性,统计访问网站的所有独立ip 3,好用推荐时,根据tag求交集,大于某个阈值就可以推荐
5. <zadd key score1 member1 score2 member2 ...> 可添加一个或多个值
类型 : Sorted Set(有序集合)
简介: 将Set中的元素增加一个权重参数score,元素按score有序排列
特性 : 数据插入集合时,已经进行天然排序
场景: 1.排行榜 2.带权重的消息队列
键值相关命令:
1. keys * 查看当前所有的key
2. exists name 查看数据库是否有name这个key
3. del name 删除key name
4. expire confirm 100 设置confirm这个key100秒过期
5. ttl confirm 获取confirm 这个key的有效时长
6. select 0 选择到0数据库 redis默认的数据库是0~15一共16个数据库
7. move confirm 1 将当前数据库中的key移动到其他的数据库中,这里就是把confire这个key从当前数据库中移动到1中
8. persist confirm 移除confirm这个key的过期时间
9. randomkey 随机返回数据库里面的一个key
10. rename key2 key3 重命名key2 为key3
11. type key2 返回key的数据类型
服务器相关命令:
1. ping PING返回响应是否连接成功
2. echo 在命令行打印一些内容
3. select 0~15 编号的数据库
4. quit 退出客户端
5. dbsize 返回当前数据库中所有key的数量
6. info 返回redis的相关信息
7. config get dir/* 实时传储收到的请求
8. flushdb 删除当前选择数据库中的所有key
9. flushall 删除所有数据库中的数据库
Tips:
打开cmd输入 redis-cli.exe 即可进入redis命令行
"""
# -*- coding:utf-8 -*-
import redis
import pickle
import datetime
__author__ = 'Evan'
class Redis(object):
def __init__(self, host='localhost', port=6379, db=0, password=''):
"""
初始化Redis连接池
:param host: 主机名
:param port: 端口
:param db: 数据库
:param password: 密码
"""
pool = redis.ConnectionPool(
host=host,
port=port,
db=db,
password=password,
max_connections=None # 连接池最大值,默认2**31
)
self.redis = redis.Redis(connection_pool=pool)
def __del__(self):
"""程序结束后,自动关闭连接,释放资源"""
self.redis.connection_pool.disconnect()
def exists(self, name):
"""
检查name是否存在
:param name:
:return:
"""
return self.redis.exists(name)
def delete(self, name):
"""
删除指定的name
:param name:
:return:
"""
return self.redis.delete(name)
def rename(self, old, new):
"""
重命名
:param old:
:param new:
:return:
"""
if self.exists(old):
return self.redis.rename(old, new)
def set_expire_by_second(self, name, second=60 * 60 * 24 * 7):
"""
以秒为单位设置过期时间
:param name:
:param second: 默认7天
:return:
"""
return self.redis.expire(name, time=second)
def remove_expire(self, name):
"""
移除name的过期时间,name将持久保持
:param name:
:return:
"""
return self.redis.persist(name)
def get_expire_by_second(self, name):
"""
以秒为单位返回name的剩余过期时间
:param name:
:return:
"""
return self.redis.ttl(name)
def get_name_type(self, name):
"""
获取name的数据类型
:param name:
:return:
"""
return self.redis.type(name).decode()
def check_name_type(self, name, expect_type='string'):
"""
检查name的数据类型
数据类型对照表:
set -> 'string'
hset -> 'hash'
lpush -> 'list'
sadd -> 'set'
zadd -> 'zset'
:param name:
:param expect_type: string / hash / list / set / zset
:return:
"""
name_type = self.get_name_type(name)
if name_type == expect_type:
return True
else:
return False
def set(self, name, value, do_pickle=True, expire=60 * 60 * 24 * 7):
"""
添加set类型,使用pickle进行持久化存储
:param name:
:param value:
:param do_pickle: 是否使用pickle进行二进制序列化,默认True
:param expire: 单位second,默认7天
:return:
"""
if do_pickle:
self.redis.set(name=name, value=pickle.dumps(value), ex=expire)
else:
self.redis.set(name=name, value=value, ex=expire)
def get_set_value(self, name, do_pickle=True):
"""
获取指定的set value
:param name:
:param do_pickle: 是否使用pickle进行二进制反序列化,默认True
:return:
"""
value = self.redis.get(name=name)
if value:
if do_pickle:
return pickle.loads(value)
else:
return value
else:
return None
def get_set_all(self, do_pickle=True):
"""
获取所有的set value
:param do_pickle: 是否使用pickle进行二进制反序列化,默认True
:return: [{}, {}, {}]
"""
all_data = []
if self.redis.keys():
for key in self.redis.keys(): # 获取所有的key
flag = self.check_name_type(name=key, expect_type='string') # 判断是否为set类型
if not flag:
continue
value = self.get_set_value(name=key, do_pickle=do_pickle)
all_data.append({key.decode(): value})
return all_data
def zadd(self, name, value=[], do_pickle=True, expire=60 * 60 * 24 * 7):
"""
添加有序集合类型,默认score为当前时间戳,使用pickle进行持久化存储
:param name:
:param value: [{}, {}, {}]
:param do_pickle: 是否使用pickle进行二进制序列化,默认True
:param expire: 单位second,默认7天
:return:
"""
assert value, 'value不能为空'
value_dict = {}
for each in value:
score = each.get('timestamp') or datetime.datetime.now().timestamp() # 如果没有timestamp,取当前时间戳为score
if do_pickle:
value_dict.setdefault(pickle.dumps(each), score)
else:
value_dict.setdefault(str(each), score) # 如果不进行序列化,需要将字典转化为字符串作为Key,否则会报错
self.redis.zadd(name=name, mapping=value_dict)
self.set_expire_by_second(name, expire) # 设置expire
def get_zadd_data_by_score(self, name, start_score=None, end_score=None, do_pickle=True):
"""
根据score范围,返回对应的数据,只用于有序集合
:param name:
:param start_score: timestamp时间戳
:param end_score: timestamp时间戳
:param do_pickle: 是否使用pickle进行二进制序列化,默认True
:return:
"""
# 如果start_score为空,默认为前一天的时间戳
start_score = start_score or (datetime.datetime.now() - datetime.timedelta(days=1)).timestamp()
# 如果end_score为空,默认为当前时间的时间戳
end_score = end_score or datetime.datetime.now().timestamp()
data = self.redis.zrangebyscore(name, start_score, end_score)
if do_pickle:
return [pickle.loads(i) for i in data]
else:
return [i for i in data]
def delete_zadd_data_by_score(self, name, start_score, end_score):
"""
根据score范围,删除对应的数据,只用于有序集合
:param name:
:param start_score: timestamp时间戳
:param end_score: timestamp时间戳
:return:
"""
return self.redis.zremrangebyscore(name, start_score, end_score)
def get_zadd_timestamp_range(self, name):
"""
获取指定name对应集合中的score最小值和最大值,只用于有序集合
:param name:
:return: [start_datetime, end_datetime]
"""
status = self.exists(name)
if status != 0:
# 转换为datetime类型
start_datetime = datetime.datetime.fromtimestamp(self.redis.zrange(name,
start=0,
end=0,
desc=False,
withscores=True)[0][1])
end_datetime = datetime.datetime.fromtimestamp(self.redis.zrange(name,
start=0,
end=0,
desc=True,
withscores=True)[0][1])
return [start_datetime, end_datetime]
else:
return []
if __name__ == '__main__':
REDIS = Redis()
# 测试set
REDIS.set(name='name', value='Evan', do_pickle=True, expire=60)
REDIS.set(name='id', value=6, do_pickle=True, expire=60)
print(REDIS.get_set_value('name', do_pickle=True))
print(REDIS.get_set_all())
# 测试有序集合
REDIS.zadd(name='demo', value=[{'name': 'Evan'}, {'id': 6}], do_pickle=True, expire=60)
print(REDIS.get_zadd_data_by_score(name='demo', do_pickle=True))
print(REDIS.get_zadd_timestamp_range(name='demo'))运行结果:
Evan
[{'name': 'Evan'}, {'id': 6}]
[{'id': 6}, {'name': 'Evan'}]
[datetime.datetime(2021, 1, 16, 19, 18, 57, 153845), datetime.datetime(2021, 1, 16, 19, 18, 57, 153845)]相关推荐
- diskdigger官网入口(diskinfo官网)
-
打开LaunchCenterPro,创建一个叫Omnifocus的操作组,然后再往这个操作组添加新的操作。如果你要在Omnifocus创建新收件箱项,添加URL到LaunchCenter...
- 最新英特尔处理器排名(最新英特尔处理器排名第几)
-
一、英特尔酷睿i7670。这款英特尔CPU采用的是超频新芯,最大程度的提升处理器的超频能力。二、英特尔酷睿i74790kCPU:这款CPU采用22纳米制程工艺的框架,它的默认频率是4.0到4.4Ghz...
-
- nvidia旧版本驱动下载(nvidia新版本驱动)
-
没法装,n卡本身不具备装旧版驱动的功能一、首先在本机电脑内鼠标左键双击打开“驱动人生”(若电脑上无此软件,可以在各大软件市场内下载安装)。二、打开驱动人生软件后,点击“立即体检”进行驱动扫描。三、驱动扫描完成后,点击显卡右边的“箭头”打开驱...
-
2025-12-18 20:51 off999
- 怎么解开别人的wifi密码(如何解开别人的wifi密码)
-
别人的无线网络密码是很不容易破解的,如果人家是愿意分享的,可以在手机上下载"Wifi万能钥匙"注册登陆成功后连接其无线wifi1、以现有的技术手段,是没有办法破解WPA的加密方式(现在...
-
- 电脑突然关机(电脑突然关机像断电了一样 再也打不开)
-
如果是插电源的电脑开着突然就关机了,可能是线路接触不良或者是没电了,导致的开着就关机了,如果是你的电脑是充电的那一种可能是你的电池的电量用完了或者是电池的线路接触不良导致的开着突然就关机了,你可以排查一下线路。1、如果你使用的是笔记本电脑,...
-
2025-12-18 19:51 off999
- win7重装系统一直反复重启(win7重装系统无限重启)
-
WIN7的系统装重复了,可以将原安装的系统删除,方法如下:1、如果以前的windows是安装在C盘上的话,点击桌面上的计算机,选中C盘,鼠标右键选择属性;2、点磁盘清理;3、点清理系统文件,点确定;4...
- 电脑如何格式化sd卡(电脑格式化sd卡,提示写有保护)
-
要在电脑上格式化SD卡,可以按照以下步骤:1.将SD卡插入计算机的SD卡读卡器中。2.打开“我的电脑”或“此电脑”,找到SD卡在计算机上的驱动器号(比如E盘)。3.右键单击SD卡驱动器,选择“格...
- 系统检测不到机械硬盘(系统检测不到机械硬盘怎么办)
-
第一,我们需要确认一下机械硬盘是否连接正常。可以检查一下硬盘的电源线和数据线是否插紧,是否松动或者断开。如果发现有松动或者断开的情况,可以重新插上并确保插紧。如果硬盘连接正常,但电脑仍然无法读取,那么...
- 路由器管理平台登录(路由器管理平台登录网址)
-
路由器的用户登录入口地址是:tplogin.cn电信运营商定制款登录地址是:192.168.2.1或者192.168.8.12、华为(容易)路由器华为路由器跟荣耀路由器只有IP地址,没有域名,它是...
- directx修复(DirectX修复工具官网下载)
-
使用DirectX修复工具很简单。首先需要下载并安装工具,然后打开工具并按照界面提示进行操作即可。工具的作用是自动检测系统中可能存在的DirectX问题,并尝试修复它们,从而保证计算机游戏等应用程序的...
-
- 网易邮箱app官方下载安装(网易邮箱163)
-
有些东西调用外部下载软件(如迅雷)是无法下载的,有时下载后不能正常打开,请尝试:在所要下载的文件上点击右键,选择“目标另存为”,也许就能成功下载。下载从网易163邮箱发来的云附件的步骤如下:1.成功登录网易邮箱后,我们点击页面左上角的“收件...
-
2025-12-18 16:51 off999
- 产品密钥是什么意思(产品密钥有什么用处)
-
产品密钥是产品授权的证明,有了它才能使用这个产品。软件商在生产自己产品时,为每个产品输入一个序列号(注册号/密钥),如“KH2J9-PC326-T44D4-39H6V-TVPBY”,用户要通过这个序列...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
