数据库
首页 > 数据库> > 踩坑日记(二)Redis篇

踩坑日记(二)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