百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python连接Redis数据库进行增删改查(附带常用方法)

off999 2024-11-04 13:16 56 浏览 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)]

相关推荐

安全教育登录入口平台(安全教育登录入口平台官网)

122交通安全教育怎么登录:122交通网的注册方法是首先登录网址http://www.122.cn/,接着打开网页后,点击右上角的“个人登录”;其次进入邮箱注册,然后进入到注册页面,输入相关信息即可完...

大鱼吃小鱼经典版(大鱼吃小鱼经典版(经典版)官方版)

大鱼吃小鱼小鱼吃虾是于谦跟郭麒麟的《我的棒儿呢?》郭德纲说于思洋郭麒麟作诗的相声,最后郭麒麟做了一首,师傅躺在师母身上大鱼吃小鱼小鱼吃虾虾吃水水落石出师傅压师娘师娘压床床压地地动山摇。...

谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)

要想将ppt免费转换为pdf的话,我们建议大家可以下一个那个wps,如果你是会员的话,可以注册为会员,这样的话,在wps里面的话,就可以免费将ppt呢转换为pdfpdf之后呢,我们就可以直接使用,不需要去直接不需要去另外保存,为什么格式转...

2026-02-04 09:03 off999

电信宽带测速官网入口(电信宽带测速官网入口app)

这个网站看看http://www.swok.cn/pcindex.jsp1.登录中国电信网上营业厅,宽带光纤,贴心服务,宽带测速2.下载第三方软件,如360等。进行在线测速进行宽带测速时,尽...

植物大战僵尸95版手机下载(植物大战僵尸95 版下载)

1可以在应用商店或者游戏平台上下载植物大战僵尸95版手机游戏。2下载教程:打开应用商店或者游戏平台,搜索“植物大战僵尸95版”,找到游戏后点击下载按钮,等待下载完成即可安装并开始游戏。3注意:确...

免费下载ppt成品的网站(ppt成品免费下载的网站有哪些)

1、Chuangkit(chuangkit.com)直达地址:chuangkit.com2、Woodo幻灯片(woodo.cn)直达链接:woodo.cn3、OfficePlus(officeplu...

2025世界杯赛程表(2025世界杯在哪个国家)

2022年卡塔尔世界杯赛程公布,全部比赛在卡塔尔境内8座球场举行,2022年,决赛阶段球队全部确定。揭幕战于当地时间11月20日19时进行,由东道主卡塔尔对阵厄瓜多尔,决赛于当地时间12月18日...

下载搜狐视频电视剧(搜狐电视剧下载安装)

搜狐视频APP下载好的视频想要导出到手机相册里方法如下1、打开手机搜狐视频软件,进入搜狐视频后我们点击右上角的“查找”,找到自已喜欢的视频。2、在“浏览器页面搜索”窗口中,输入要下载的视频的名称,然后...

pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
永久免费听歌网站(丫丫音乐网)

可以到《我爱音乐网》《好听音乐网》《一听音乐网》《YYMP3音乐网》还可以到《九天音乐网》永久免费听歌软件有酷狗音乐和天猫精灵,以前要跳舞经常要下载舞曲,我从QQ上找不到舞曲下载就从酷狗音乐上找,大多...

音乐格式转换mp3软件(音乐格式转换器免费版)

有两种方法:方法一在手机上操作:1、进入手机中的文件管理。2、在其中选择“音乐”,将显示出手机中的全部音乐。3、点击“全选”,选中所有音乐文件。4、点击屏幕右下方的省略号图标,在弹出菜单中选择“...

电子书txt下载(免费的最全的小说阅读器)

1.Z-library里面收录了近千万本电子书籍,需求量大。2.苦瓜书盘没有广告,不需要账号注册,使用起来非常简单,直接搜索预览下载即可。3.鸠摩搜书整体风格简洁清晰,书籍资源丰富。4.亚马逊图书书籍...

最好免费观看高清电影(播放免费的最好看的电影)

在目前的网上选择中,IMDb(互联网电影数据库)被认为是最全的电影网站之一。这个网站提供了各种类型的电影和电视节目的海量信息,包括剧情介绍、演员表、评价、评论等。其还提供了有关电影制作背后的详细信息,...

孤单枪手2简体中文版(孤单枪手2简体中文版官方下载)

要将《孤胆枪手2》游戏的征兵秘籍切换为中文,您可以按照以下步骤进行操作:首先,打开游戏设置选项,通常可以在游戏主菜单或游戏内部找到。然后,寻找语言选项或界面选项,点击进入。在语言选项中,选择中文作为游...

取消回复欢迎 发表评论: