连接

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")) # 集合长度
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。