Redis是一个基于内存的高效的键值型非关系型数据库,存取效率极高,而且支持多种存储数据结构,使用也非常简单。本节中,我们就来介绍一下Python的Redis操作,主要介绍RedisPy这个库的用法。
1. 准备工作
在开始之前,请确保已经安装好了Redis及RedisPy库。如果要做数据导入/导出操作的话,还需要安装RedisDump。
2. Redis 和 StrictRedis
RedisPy库提供两个类Redis和StrictRedis来实现Redis的命令操作。
StrictRedis实现了绝大部分官方的命令,参数也一一对应,比如set()方法就对应Redis命令的set方法。而Redis是StrictRedis的子类,它的主要功能是用于向后兼容旧版本库里的几个方法。为了做兼容,它将方法做了改写,比如lrem()方法就将value和num参数的位置互换,这和Redis命令行的命令参数不一致。
官方推荐使用StrictRedis,所以本节中我们也用StrictRedis类的相关方法作演示。
3. 连接Redis
现在我们已经在本地安装了Redis并运行在6379端口,密码设置为foobared。那么,可以用如下示例连接Redis并测试:
from redis import StrictRedis
redis = StrictRedis(host='localhost', port=6379, db=0, password='foobared')
redis.set('name', 'Bob')
print(redis.get('name'))
这里我们传入了Redis的地址、运行端口、使用的数据库和密码信息。在默认不传的情况下,这4个参数分别为localhost、6379、0和None。首先声明了一个StrictRedis对象,接下来调用set()方法,设置一个键值对,然后将其获取并打印。
运行结果如下:
b'Bob'
这说明我们连接成功,并可以执行set()和get()操作了。
当然,我们还可以使用ConnectionPool来连接,示例如下:
from redis import StrictRedis, ConnectionPool
pool = ConnectionPool(host='localhost', port=6379, db=0, password='foobared')
redis = StrictRedis(connection_pool=pool)
这样的连接效果是一样的。观察源码可以发现,StrictRedis内其实就是用host和port等参数又构造了一个ConnectionPool,所以直接将ConnectionPool当作参数传给StrictRedis也一样。
另外,ConnectionPool还支持通过URL来构建。URL的格式支持有如下3种:
redis://[:password]@host:port/db
rediss://[:password]@host:port/db
unix://[:password]@/path/to/socket.sock?db=db
这3种URL分别表示创建Redis TCP连接、Redis TCP+SSL连接、Redis UNIX socket连接。我们只需要构造上面任意一种URL即可,其中password部分如果有则可以写,没有则可以省略。下面再用URL连接演示一下:
url = 'redis://:foobared@localhost:6379/0'
pool = ConnectionPool.from_url(url)
redis = StrictRedis(connection_pool=pool)
这里我们使用第一种连接字符串进行连接。首先,声明一个Redis连接字符串,然后调用from_url()方法创建ConnectionPool,接着将其传给StrictRedis即可完成连接,所以使用URL的连接方式还是比较方便的。
4. 键操作
下表总结了键的一些判断和操作方法。
方法作用参数说明示例示例说明示例结果
exists(name)
判断一个键是否存在
name:键名
redis.exists('name')
是否存在name这个键
True
delete(name)
删除一个键
name:键名
redis.delete('name')
删除name这个键
1
type(name)
判断键类型
name:键名
redis.type('name')
判断name这个键类型
b'string'
keys(pattern)
获取所有符合规则的键
pattern:匹配规则
redis.keys('n*')
获取所有以n开头的键
[b'name']
randomkey()
获取随机的一个键
randomkey()
获取随机的一个键
b'name'
rename(src, dst)
重命名键
src:原键名;dst:新键名
redis.rename('name', 'nickname')
将name重命名为nickname
True
dbsize()
获取当前数据库中键的数目
dbsize()
获取当前数据库中键的数目
100
expire(name, time)
设定键的过期时间,单位为秒
name:键名;time:秒数
redis.expire('name', 2)
将name键的过期时间设置为2秒
True
ttl(name)
获取键的过期时间,单位为秒,-1表示永久不过期
name:键名
redis.ttl('name')
获取name这个键的过期时间
-1
move(name, db)
将键移动到其他数据库
name:键名;db:数据库代号
move('name', 2)
将name移动到2号数据库
True
flushdb()
删除当前选择数据库中的所有键
flushdb()
删除当前选择数据库中的所有键
True
flushall()
删除所有数据库中的所有键
flushall()
删除所有数据库中的所有键
True
5. 字符串操作
Redis支持最基本的键值对形式存储,用法总结如下表所示。
方法作用参数说明示例示例说明示例结果
set(name, value)
给数据库中键为name的string赋予值value
name: 键名;value: 值
redis.set('name', 'Bob')
给name这个键的value赋值为Bob
True
get(name)
返回数据库中键为name的string的value
name:键名
redis.get('name')
返回name这个键的value
b'Bob'
getset(name, value)
给数据库中键为name的string赋予值value并返回上次的value
name:键名;value:新值
redis.getset('name', 'Mike')
赋值name为Mike并得到上次的value
b'Bob'
mget(keys, *args)
返回多个键对应的value</