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

总结:认真是成功的秘诀,粗心是失败的伴侣。

上一篇:数仓工具—Hive进阶之优化map任务数量(9)


下一篇:mybatis配置解析