踩坑日记(二)Redis篇
作者:互联网
此篇文章用以记录python操作redis时容易忽略的问题。
首先,连接redis
import redis
r = redis.StrictRedis(host='localhost', port=6379, db=0)
随便写个东西进去
r.sadd('test01', 1, 2, 3, 4, 5, 5)
输出:5
这是因为此处使用的是redis的集合类型,而集合中的元素是不能重复的,存进去的数字中,有重复元素,去除重复的元素后,只剩下剩下5个元素,被存入到redis数据库中。
取出所有元素:
r.smembers('test01')
输出:{b'1', b'2', b'3', b'4', b'5'}
输出元素类型试试:
test01 = r.smembers('test01')
for i in test01:
print(type(i))
print(i)
break
输出:
<class 'bytes'>
b'2'
我们存进去的明明是int类型,取出来的时候成了bytes类型
因此,从redis中取出数据时,记得decode一下
test01 = r.smembers('test01')
for i in test01:
print(type(i))
print(i.decode('utf-8'))
print(type(i.decode('utf-8')))
break
输出:
<class 'bytes'>
2
<class 'str'>
不过,每次取出来都要decode,挺麻烦的。
还好,我们可以在连接redis时指定参数decode_responses=True
,这样我们取出来的就都是str
import redis
r = redis.StrictRedis(host='localhost', port=6379, db=0, decode_responses=True)
r.sadd('test02', 1, 2, 3, 4, 5, 5)
test02 = r.smembers('test02')
for i in test02:
print(type(i))
print(i)
break
输出:
<class 'str'>
2
总结:认真是成功的秘诀,粗心是失败的伴侣。
标签:Redis,redis,decode,type,print,test01,smembers,日记 来源: https://blog.csdn.net/qq_44193969/article/details/120403875