连接
import redis <!--more--> # host是redis主机,需要redis服务端和客户端都启动 redis默认端口是6379 redis = redis.Redis(host='127.0.0.1', port=6379, decode_responses=True)
或者使用连接池
pool = redis.ConnectionPool(host='127.0.0.1', port=6379, db=15) (decode_responses=True) # 此参数将不会存储bytes类型,而是字符串类型 # redis有 0-15,共16个数据库,默认使用0数据库 redis = redis.Redis(connection_pool=pool)
redis支持五大数据类型,
但只支持第一层,也就说任何类型的value值,必须是字符串 如果value值想存字典/列表等,必须用json/list转换一下,转成字符串
字符串
增
redis.set('age', 2) # set:有则覆盖 print(redis.get('age')) redis.set('name', 'hehe', 10) # set :添加键值字符串,有效时间10秒,有则覆盖 redis.setnx('name', 'lala') # setnx:没有才添加,有就不变 print(redis.get('name')) redis.mset(k1='v2', k2='v3') # mset:批量插入,键不用加引号,有则覆盖 print(redis.get('k1')) # 取的时候要加引号 redis.incr('age', 3) # 数字自加,每次执行,都在原来的基础上增加3 print(redis.get('age')) print(type(redis.get('age').decode())) # <class 'str'> 注意:存进去是数字,取出的是bytes,解码之后是字符串
删
redis.delete('age') # 删除某个键值对 redis.flushall() # 清空
改
ret = redis.getset('k1', 'vvv2') # getset:获取原来的值,设置新值 print(ret) print(redis.get('k1')) print(redis.getrange('name', 1, 3)) # getrange:对取出的值进行切片,顾头顾尾 redis.setrange('name', 2, 'll') # 将name对应的值从索引2位置替换,写几位就替换几位 print(redis.get('name')) redis.append('name', '你好') # 向字符串后追加 print(redis.get('name'))
查
ret = redis.get('name') # get :通过键取字符串,获取不到,得到None print(ret) print(redis.mget('k1', 'k2', 'name')) # mget:批量取,返回3个值 print(redis.strlen('name')) # 查看字节长度,注意字节长度和编码有关 print(redis.get('name').decode('utf8')) # 解码成字符串,utf8编码格式,如果有中文,以gbk解码会乱码 print(redis.keys()) # 查看都有哪些键 print(redis.keys('shoppingcar_1*')) # 查看所有以shoppingcar_1开头的键 print(redis.mget('k1', 'k2', 'name', 'age'))
有序set
增
zadd(name, args, *kwargs) -在name对应的有序集合中添加元素
redis.zadd("zset1", n1=11, n2=22) redis.zadd("zset2", 'm1', 22, 'm2', 44) print(redis.zcard("zset1")) # 集合长度 print(redis.zcard("zset2")) # 集合长度 print(redis.zrange("zset1", 0, -1)) # 获取有序集合中所有元素 print(redis.zrange("zset2", 0, -1, withscores=True)) # 获取有序集合中所有元素和分数
获取有序集合元素个数 类似于len
zcard(name) – 获取name对应的有序集合元素的数量
print(r.zcard("zset1")) # 集合长度
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)