Python 操作 Redis 数据库(python连接redis数据库)
off999 2024-11-04 13:16 20 浏览 0 评论
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键对应的值,超时后获取值为None
print(rs.get('color'))
# 如果color存在输出None,如果不存在,则输出True
print(rs.set('color', 'green', nx=True))
# 如果color存在输出True,如果不存在,则输出None
print(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', '!') #返回结果: 15
print(rs.get('lang')) #返回结果:China is great!
# 返回lang对应值的长度
print(rs.strlen('lang')) #返回结果:15
# 如果total对应值不存在,则total当前值设置为10
rs.incr('total', amount=10)
# 当前total对应值增加1
rs.incr('total') #结果为11
# 当前total对应值减少1
rs.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中所有的keys
print(rs.hkeys('hName')) #返回结果:['key1', 'key2', 'key3', 'key5']
# 取hName中所有的values
print(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'])
# 再次创建一个集合mySet2
rs.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 的特点:一个不允许重复的集合,集合中元素是有序的,每个元素有两个值:值和分数,分数专门用来做排序。
# 增加集合元素,如集合不存在则新建
rs.zadd('fruits', {'apple':1, 'banana':3, 'orange':5})
# 遍历所有元素
print(rs.zrange("fruits", 0, -1)) #结果:['apple', 'banana', 'orange']
# withscores=True指带上分数
print(rs.zrange("fruits", 0, -1, withscores=True)) #结果:[('apple', 1.0), ('banana', 3.0), ('orange', 5.0)]
# 根据分数由大到小遍历所有元素
print(rs.zrevrange("fruits", 0, -1)) #结果:['orange', 'banana', 'apple']
# 获取orange元素对应的分数
rs.zscore('fruits', 'orange') #结果:5.0
# 取出分数>=3 and 分数<=5的元素
print(rs.zrangebyscore('fruits', 3, 5))
# 取出分数<=5 and 分数>=3的元素,根据分数从大到小排序
print(rs.zrevrangebyscore('fruits', 5, 3))
# 遍历所有元素,返回一个元组
print(rs.zscan('fruits')) #结果:(0, [('apple', 1.0), ('banana', 3.0), ('orange', 5.0)])
# 打印集合元素个数
print(rs.zcard('fruits')) #结果:3
# 返回集合中分数>=1 and 分数<=3元素个数
print(rs.zcount('fruits', 1, 3))
# 将集合中apple元素的分数+5
rs.zincrby('fruits', 5, 'apple')
print(rs.zrange("fruits", 0, -1, withscores=True)) #返回结果:[('banana', 3.0), ('orange', 5.0), ('apple', 6.0)]
# 返回orange元素在集合中的索引号
rs.zrank('fruits', 'orange') #结果:1
# 按分数从大到小排序,取出banana元素索引号
rs.zrevrank('fruits', 'banana') #结果:2
# #删除集合中apple元素
rs.zrem('fruits', 'apple')
print(rs.zrange("fruits", 0, -1)) #返回结果:['banana', 'orange']
# #删除集合索引号>=0 and 索引号<=2的元素
rs.zremrangebyrank('fruits', 0, 2)
# 删除集合分数>=1 and 分数<=5的元素
rs.zremrangebyscore('fruits', 1, 5)
其他操作方法
以下操作方法针对 redis 任意数据类型(字符串,list,hash,set,zset),可以删除 key ,查询 key 是否存在,还可设置超时,重命名 key 的名称等:
# 删除key为color的对象
rs.delete('color')
# 查询key为color的对象是否存在
print(rs.exists('color')) #结果:False
rs.sadd('mySet5', 'one', 'two')
# 设置key的超时时间
rs.expire('mySet5', time=5) #单位:秒
# 重命名key的值
rs.rename('mySet5', 'set5')
# 随机返回当前库中一个key,但不会删除
print(rs.randomkey())
# 查看某个key对应值的类型
print(rs.type('mySet')) #返回结果:set
# 通过模糊匹配出满足条件的key
print(rs.keys('my*')) #返回结果:['mySet', 'mySet2']
#各类型元素迭代方式
#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 数据库,并通过代码的方式展示了 Redis 支持的各数据类型的操作方法,通过学习发现操作起来还是很方便的,接下来还会为大家介绍其他数据库的操作。
相关推荐
- 面试官:来,讲一下枚举类型在开发时中实际应用场景!
-
一.基本介绍枚举是JDK1.5新增的数据类型,使用枚举我们可以很好的描述一些特定的业务场景,比如一年中的春、夏、秋、冬,还有每周的周一到周天,还有各种颜色,以及可以用它来描述一些状态信息,比如错...
- 一日一技:11个基本Python技巧和窍门
-
1.两个数字的交换.x,y=10,20print(x,y)x,y=y,xprint(x,y)输出:102020102.Python字符串取反a="Ge...
- Python Enum 技巧,让代码更简洁、更安全、更易维护
-
如果你是一名Python开发人员,你很可能使用过enum.Enum来创建可读性和可维护性代码。今天发现一个强大的技巧,可以让Enum的境界更进一层,这个技巧不仅能提高可读性,还能以最小的代价增...
- Python元组编程指导教程(python元组的概念)
-
1.元组基础概念1.1什么是元组元组(Tuple)是Python中一种不可变的序列类型,用于存储多个有序的元素。元组与列表(list)类似,但元组一旦创建就不能修改(不可变),这使得元组在某些场景...
- 你可能不知道的实用 Python 功能(python有哪些用)
-
1.超越文件处理的内容管理器大多数开发人员都熟悉使用with语句进行文件操作:withopen('file.txt','r')asfile:co...
- Python 2至3.13新特性总结(python 3.10新特性)
-
以下是Python2到Python3.13的主要新特性总结,按版本分类整理:Python2到Python3的重大变化Python3是一个不向后兼容的版本,主要改进包括:pri...
- Python中for循环访问索引值的方法
-
技术背景在Python编程中,我们经常需要在循环中访问元素的索引值。例如,在处理列表、元组等可迭代对象时,除了要获取元素本身,还需要知道元素的位置。Python提供了多种方式来实现这一需求,下面将详细...
- Python enumerate核心应用解析:索引遍历的高效实践方案
-
喜欢的条友记得关注、点赞、转发、收藏,你们的支持就是我最大的动力源泉。根据GitHub代码分析统计,使用enumerate替代range(len())写法可减少38%的索引错误概率。本文通过12个生产...
- Python入门到脱坑经典案例—列表去重
-
列表去重是Python编程中常见的操作,下面我将介绍多种实现列表去重的方法,从基础到进阶,帮助初学者全面掌握这一技能。方法一:使用集合(set)去重(最简单)pythondefremove_dupl...
- Python枚举类工程实践:常量管理的标准化解决方案
-
本文通过7个生产案例,系统解析枚举类在工程实践中的应用,覆盖状态管理、配置选项、错误代码等场景,适用于Web服务开发、自动化测试及系统集成领域。一、基础概念与语法演进1.1传统常量与枚举类对比#传...
- 让Python枚举更强大!教你玩转Enum扩展
-
为什么你需要关注Enum?在日常开发中,你是否经常遇到这样的代码?ifstatus==1:print("开始处理")elifstatus==2:pri...
- Python枚举(Enum)技巧,你值得了解
-
枚举(Enum)提供了更清晰、结构化的方式来定义常量。通过为枚举添加行为、自动分配值和存储额外数据,可以提升代码的可读性、可维护性,并与数据库结合使用时,使用字符串代替数字能简化调试和查询。Pytho...
- 78行Python代码帮你复现微信撤回消息!
-
来源:悟空智能科技本文约700字,建议阅读5分钟。本文基于python的微信开源库itchat,教你如何收集私聊撤回的信息。[导读]Python曾经对我说:"时日不多,赶紧用Python"。于是看...
- 登录人人都是产品经理即可获得以下权益
-
文章介绍如何利用Cursor自动开发Playwright网页自动化脚本,实现从选题、写文、生图的全流程自动化,并将其打包成API供工作流调用,提高工作效率。虽然我前面文章介绍了很多AI工作流,但它们...
- Python常用小知识-第二弹(python常用方法总结)
-
一、Python中使用JsonPath提取字典中的值JsonPath是解析Json字符串用的,如果有一个多层嵌套的复杂字典,想要根据key和下标来批量提取value,这是比较困难的,使用jsonpat...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python自定义函数 (53)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python串口编程 (60)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python人脸识别 (54)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)