热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

操作ex_第75天:Python操作Redis数据库介绍

Redis作为常用的NoSql数据库,主要用于缓存数据,提高数据读取效率,那在Python中应该如果连接和操作Redis呢?

1c0955dd0dc8f0f7bf5344d537257eda.png

Redis 作为常用的 NoSql 数据库,主要用于缓存数据,提高数据读取效率,那在 Python 中应该如果连接和操作 Redis 呢?今天就为大概简单介绍下,在 Python 中操作 Redis 常用命令。

安装 redis

首先还是需要先安装 redis 模块,使用如下命令:

$ pip3 install redis

创建 redis 连接池

安装成功后就可以在代码中导入模块,然后通过创建连接池的方式,连接到 Redis 服务器,创建代码如下:

import redis #导入redis模块# 建议使用以下连接池的方式# 设置decode_responses=True,写入的KV对中的V为string类型,不加则写入的为字节类型。pool = redis.ConnectionPool(host='127.0.0.1', port=6379, db=0, decode_responses=True)rs = redis.Redis(connection_pool=pool)

需要注意的是,设置 decode_responses=True,写入的 Key/Value 对中的 Value 为 string 类型,不加则写入的为字节类型。

Redis 操作方法

Redis 支持五种类型的数据操作,分别为字符串、 List、 Hash、 Set、 zSet类型,还有一些方法是不区分类型操作的。上面我们已经连接到 Redis 服务器,接下来为大家介绍各类型基本的操作方法。

字符串类型方法

  • 单键值操作

set(name, value, ex=None, px=None, nx=False, xx=False)

参数说明:

  • ex:过期时间(秒)
  • px:过期时间(毫秒)
  • nx:如果设置为True,则只有name不存在时,当前set操作才执行
  • xx:如果设置为True,则只有name存在时,当前set操作才执行

使用方法如下:

# key="color",value="red",设置过期时间5秒rs.set('color', 'red', ex=5)# 与rs.set('color', 'red', ex=5)相同rs.setex('color', 5, 'red')# 打印获取color键对应的值,超时后获取值为Noneprint(rs.get('color'))# 如果color存在输出None,如果不存在,则输出Trueprint(rs.set('color', 'green', nx=True))# 如果color存在输出True,如果不存在,则输出Noneprint(rs.set('color', 'yellow', xx=True))

  • 批量键值操作

可以批量对多个 key 赋值,也可以同时获取多个 key 的值,使用方法如下:

# 批量赋值rs.mset({'key1':'value1', 'key2':'value2', 'key3':'value3'})# 批量获取值rs.mget('key1', 'key2', 'key3')

  • 其他操作

除了基础的赋值和取值,可以在赋新值时返回旧值,还可将返回值通过索引来截取,也可以在 key 对应值后追回值等,具体使用可见以下代码:

# 设置新值为blue,同时返回设置前的值print(rs.getset('color', 'blue'))rs.set('lang', 'Chinese')# 取索引为1-3字符print(rs.getrange('lang', 1, 3)) #返回结果:hin# 从索引号为4字符开始向后替换rs.setrange('lang', 4, 'a is great') #返回结果:14# 在lang对应值后面追加字符 "!"rs.append('lang', '!') #返回结果:15print(rs.get('lang')) #返回结果:China is great!# 返回lang对应值的长度print(rs.strlen('lang')) #返回结果:15# 如果total对应值不存在,则total当前值设置为10rs.incr('total', amount=10)# 当前total对应值增加1rs.incr('total') #结果为11# 当前total对应值减少1rs.decr('total') #结果为10

list 类型方法

list 的特点:一个有序的列表,列表中的元素可以重复,并且可以在列表前后或中间任意位置插入新元素,具体使用方式见如下代码:

# 每个新增元素都插入到list最左边,如果list不存在则会新建rs.lpush('leftList', 1,2,3,4,5)print(rs.lrange('leftList', 0, -1)) #返回结果:['5', '4', '3', '2', '1']# 新插入元素在右侧,如果list不存在则新建rs.rpush('rightList', 6,7,8,9,10)print(rs.lrange('rightList', 0, -1)) #返回结果:['6', '7', '8', '9', '10']# 在list左边新增元素,如果list不存在则不创建rs.lpushx('noList', 'apple')print(rs.llen('noList')) #返回结果:0# 在list中从左遍历出第一个为'7'的元素,在它后面(如果是在前面插入则用'before')插入元素'08'rs.linsert('rightList', 'after', '7', '08') print(rs.lrange('rightList', 0, -1)) #返回结果:['6', '7', '08', '8', '9', '10']# 将list中索引号为1的元素修改为'-7'rs.lset('rightList', 1, '-7')print(rs.lrange('rightList', 0, -1)) #返回结果:['6', '-7', '08', '8', '9', '10']# 删除list中从左遍历第一个为'8'的元素rs.lrem('rightList', '8', 1)print(rs.lrange('rightList', 0, -1)) #返回结果:['6', '-7', '08', '9', '10']# 弹出左侧第一个元素rs.lpop('rightList') #返回值为:'6'print(rs.lrange('rightList', 0, -1)) #返回结果:['-7', '08', '9', '10']#取出list中索引编号为1的值print(rs.lindex('rightList', 1)) #返回结果:08

hash 类型方法

hash 的特点:一个 key 对应一个 value,并且 key 不允许重复,可以单个操作,也可以批量键值操作,下面列举了常用方法的使用方法:

# 单键值操作# 设置hash名为hName的键和值rs.hset('hName', 'key1', 'value1')rs.hset('hName', 'key2', 'value2')# 取hName的key1对应的值print(rs.hget('hName', 'key1')) #返回结果:value1#批量键值操作rs.hmset('hName', {'key3': 'value3', 'key5': 'value5'})print(rs.hmget('hName', 'key1', 'key2', 'key3')) #返回结果:['value1', 'value2', 'value3']# 取出hName所有键值print(rs.hgetall('hName')) #返回结果:{'key1': 'value1', 'key2': 'value2', 'key3': 'value3', 'key5': 'value5'}# 取hName中所有的keysprint(rs.hkeys('hName')) #返回结果:['key1', 'key2', 'key3', 'key5']# 取hName中所有的valuesprint(rs.hvals('hName')) #返回结果:['value1', 'value2', 'value3', 'value5']# 获取hName对应hash键值对个数print(rs.hlen('hName')) #返回结果:4# 判断key2是否存在print(rs.hexists('hName', 'key2')) #返回结果:True# 删除key2对应键值对rs.hdel('hName', 'key2')# 再次判断key2是否存在print(rs.hexists('hName', 'key2')) #返回结果:False

set 类型方法

set 的特点:一个无序的元素集合,集合中元素不能重复,可以随机 pop 元素,两个集合可以取交集,并集,差集运算。

# 增加集合元素,如集合不存在则新建rs.sadd('mySet', 'one', 'two', 3)# 返回集合元素个数print(rs.scard('mySet'))# 返回所有元素print(rs.smembers('mySet')) #结果:{'two', 'one', '3'}# 返回所有成员print(rs.sscan('mySet')) #结果:(0, ['3', 'one', 'two'])# 再次创建一个集合mySet2rs.sadd('mySet2', 3, 5, 7)# 获取两个集合交集print(rs.sinter('mySet', 'mySet2')) #返回结果:{'3'}# 获取两个集合并集print(rs.sunion('mySet', 'mySet2')) #返回结果:{'5', 'two', 'one', '7', '3'}# 获取两个集合差集print(rs.sdiff('mySet', 'mySet2')) #返回结果:{'two', 'one'}# 取mySet和mySet2的并集,将结果存到storeSet集合中print(rs.sunionstore('sotreSet', 'mySet', 'mySet2'))print(rs.smembers('sotreSet')) #返回结果:{'5', 'two', 'one', '7', '3'}# 判断one元素是否存在集合中print(rs.sismember('sotreSet', 'one'))# 随机删除并返回集合中的一个元素print(rs.spop('sotreSet'))# 删除集合中元素值为5的元素print(rs.srem('sotreSet', 5))

zset 类型方法

zset 的特点:一个不允许重复的集合,集合中元素是有序的,每个元素有两个值:值和分数,分数专门用来做排序。

# 增加集合元素&#xff0c;如集合不存在则新建rs.zadd(&#39;fruits&#39;, {&#39;apple&#39;:1, &#39;banana&#39;:3, &#39;orange&#39;:5})# 遍历所有元素print(rs.zrange("fruits", 0, -1)) #结果&#xff1a;[&#39;apple&#39;, &#39;banana&#39;, &#39;orange&#39;]# withscores&#61;True指带上分数print(rs.zrange("fruits", 0, -1, withscores&#61;True)) #结果&#xff1a;[(&#39;apple&#39;, 1.0), (&#39;banana&#39;, 3.0), (&#39;orange&#39;, 5.0)]# 根据分数由大到小遍历所有元素print(rs.zrevrange("fruits", 0, -1)) #结果&#xff1a;[&#39;orange&#39;, &#39;banana&#39;, &#39;apple&#39;]# 获取orange元素对应的分数rs.zscore(&#39;fruits&#39;, &#39;orange&#39;) #结果&#xff1a;5.0# 取出分数>&#61;3 and 分数<&#61;5的元素print(rs.zrangebyscore(&#39;fruits&#39;, 3, 5))# 取出分数<&#61;5 and 分数>&#61;3的元素&#xff0c;根据分数从大到小排序print(rs.zrevrangebyscore(&#39;fruits&#39;, 5, 3))# 遍历所有元素&#xff0c;返回一个元组print(rs.zscan(&#39;fruits&#39;)) #结果&#xff1a;(0, [(&#39;apple&#39;, 1.0), (&#39;banana&#39;, 3.0), (&#39;orange&#39;, 5.0)])# 打印集合元素个数print(rs.zcard(&#39;fruits&#39;)) #结果&#xff1a;3# 返回集合中分数>&#61;1 and 分数<&#61;3元素个数print(rs.zcount(&#39;fruits&#39;, 1, 3))# 将集合中apple元素的分数&#43;5rs.zincrby(&#39;fruits&#39;, 5, &#39;apple&#39;)print(rs.zrange("fruits", 0, -1, withscores&#61;True)) #返回结果&#xff1a;[(&#39;banana&#39;, 3.0), (&#39;orange&#39;, 5.0), (&#39;apple&#39;, 6.0)]# 返回orange元素在集合中的索引号rs.zrank(&#39;fruits&#39;, &#39;orange&#39;) #结果&#xff1a;1# 按分数从大到小排序&#xff0c;取出banana元素索引号rs.zrevrank(&#39;fruits&#39;, &#39;banana&#39;) #结果&#xff1a;2# #删除集合中apple元素rs.zrem(&#39;fruits&#39;, &#39;apple&#39;)print(rs.zrange("fruits", 0, -1)) #返回结果&#xff1a;[&#39;banana&#39;, &#39;orange&#39;]# #删除集合索引号>&#61;0 and 索引号<&#61;2的元素rs.zremrangebyrank(&#39;fruits&#39;, 0, 2)# 删除集合分数>&#61;1 and 分数<&#61;5的元素rs.zremrangebyscore(&#39;fruits&#39;, 1, 5)

其他操作方法

以下操作方法针对 redis 任意数据类型(字符串&#xff0c;list&#xff0c;hash&#xff0c;set&#xff0c;zset)&#xff0c;可以删除 key &#xff0c;查询 key 是否存在&#xff0c;还可设置超时&#xff0c;重命名 key 的名称等&#xff1a;

# 删除key为color的对象rs.delete(&#39;color&#39;)# 查询key为color的对象是否存在print(rs.exists(&#39;color&#39;)) #结果&#xff1a;Falsers.sadd(&#39;mySet5&#39;, &#39;one&#39;, &#39;two&#39;)# 设置key的超时时间rs.expire(&#39;mySet5&#39;, time&#61;5) #单位&#xff1a;秒# 重命名key的值rs.rename(&#39;mySet5&#39;, &#39;set5&#39;)# 随机返回当前库中一个key&#xff0c;但不会删除print(rs.randomkey())# 查看某个key对应值的类型print(rs.type(&#39;mySet&#39;)) #返回结果&#xff1a;set# 通过模糊匹配出满足条件的keyprint(rs.keys(&#39;my*&#39;)) #返回结果&#xff1a;[&#39;mySet&#39;, &#39;mySet2&#39;]#各类型元素迭代方式#hash类型迭代for i in rs.hscan_iter("hName"): print(i)#set类型迭代for j in rs.sscan_iter("mySet"): print(j)#zset类型迭代for k in rs.zscan_iter("fruits"): print(k)

总结

本文为大家介绍了 Python 中如何创建连接 Redis 数据库&#xff0c;并通过代码的方式展示了 Redis 支持的各数据类型的操作方法&#xff0c;通过学习发现操作起来还是很方便的&#xff0c;接下来还会为大家介绍其他数据库的操作。

示例代码&#xff1a;https://github.com/JustDoPython/python-100-day/tree/master/day-075

参考&#xff1a;https://github.com/andymccurdy/redis-py

系列文章第74天&#xff1a;Python newspaper 框架第73天&#xff1a;itchat 微信机器人简介第72天&#xff1a;PySpider框架的使用第71天&#xff1a;Python Scrapy 项目实战从 0 学习 Python 0 - 70 大合集总结PS&#xff1a;公号内回复 &#xff1a;Python&#xff0c;即可进入Python 新手学习交流群&#xff0c;一起100天计划&#xff01;-END-Python 技术关于 Python 都在这里d4d36c206cd122e1a1241a25a02780ee.png



推荐阅读
  • Python瓦片图下载、合并、绘图、标记的代码示例
    本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • 超级简单加解密工具的方案和功能
    本文介绍了一个超级简单的加解密工具的方案和功能。该工具可以读取文件头,并根据特定长度进行加密,加密后将加密部分写入源文件。同时,该工具也支持解密操作。加密和解密过程是可逆的。本文还提到了一些相关的功能和使用方法,并给出了Python代码示例。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 本文介绍了机器学习手册中关于日期和时区操作的重要性以及其在实际应用中的作用。文章以一个故事为背景,描述了学童们面对老先生的教导时的反应,以及上官如在这个过程中的表现。同时,文章也提到了顾慎为对上官如的恨意以及他们之间的矛盾源于早年的结局。最后,文章强调了日期和时区操作在机器学习中的重要性,并指出了其在实际应用中的作用和意义。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • Python使用Pillow包生成验证码图片的方法
    本文介绍了使用Python中的Pillow包生成验证码图片的方法。通过随机生成数字和符号,并添加干扰象素,生成一幅验证码图片。需要配置好Python环境,并安装Pillow库。代码实现包括导入Pillow包和随机模块,定义随机生成字母、数字和字体颜色的函数。 ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
author-avatar
我的小名-_164
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有