Python 使用 Redis 相对比较简单,Python 专门提供了操作 Redis 的第三方模块,即 redis 模块,该模块可以直接使用 Python 包管理工具pip来安装。本节内容适合 Python 开发人员阅读。
下面以 Windows 系统为例,使用包管理工具安装 redis 模块,命令如下:
python -m pip install redis
如果您是 Linux 系统,需要执行以下命令来安装:
sudo pip3 install redis
redis 模块采用了两种连接模式:直接模式和连接池模式,它们都可以操作 Redis。
import redis
# 本地连接,创建数据库连接对象
r = redis.Redis(host='127.0.0.1',port=6379,db=0,password='123456')
上述代码中,db 表示当前选择的库,其参数值可以是 0-15;如果设置连接数据库的密码,那么就需要使用 password 进行验证,否则可以省略。
redis 模块使用 connection pool(连接池)来管理 redis server 的所有连接,每个 Redis 实例都会维护一个属于自己的连接池,这样做的目的是为了减少每次连接或断开的性能消耗。
下面示例,实现了多个 Redis 实例共享一个连接池,代码如下:
import redis
#创建连接池并连接到redis,并设置最大连接数量;
conn_pool = redis.ConnectionPool(host='127.0.0.1',port=6379,max_connections=10)
# 第一个客户端访问
re_pool = redis.Redis(connection_pool=conn_pool)
# 第二个客户端访问
re_pool2 = redis.Redis(connection_pool=conn_pool)
...
连接池的作用:当有新的客户端请求连接时,只需要去连接池获取一个连接即可,实际上就是把一个连接共享给多个客户端使用,这样就节省了每次连接所耗费的时间。
下面是 Python 操作 Redis 数据库的通用命令。
import redis
r = redis.Redis(host='127.0.0.1',port=6379,db=0)
print(r.keys('*'))
key_list = r.keys('*')
#转换为字符串
for key in key_list:
print(key.decode())
#查看key类型
print(r.type('webname'))
# 返回值: 0 或者 1
print(r.exists('username'))
# 删除key
r.delete('webname')
if "age" in key_list:
print("删除失败")
else:
print("删除成功")
输出结果:
[b'username', b'webname', b'age', b'password'] username webname age password b'string' 1 删除成功
示例如下:
import redis
#连接redis服务器
r = redis.Redis(host='127.0.0.1',port=6379,db=0)
#key为database
r.set('webname','www.cdsy.xyz')
print(r.get('webname'))
#mset参数为字典
r.mset({'username':'jacak','password':'123'})
print(r.mget('username','password'))
#查看value长度
print(r.strlen('username'))
#数值操作
r.set('age','15')
r.incrby('age',5)
r.decrby('age',5)
r.incr('age')
r.decr('age')
r.incrbyfloat('age',5.2)
r.incrbyfloat('age',-10.5)
print(r.get('age'))
#删除key
r.delete('username')
输出结果如下:
b'www.cdsy.xyz' [b'jacak', b'123'] 5 b'9.69999999999999929'
注意:输出结果为 bytes 形式,需要使用 decode() 方法进行转换。
示例如下:
import redis
#建立redis连接
r = redis.Redis(host='127.0.0.1',port=6379,db=0)
r.lpush('database','sql','mysql','redis')
r.linsert('database','before','mysql',',mongodb')
print(r.llen('database'))
print(r.lrange('database',0,-1))
print(r.rpop('database'))
#保留指定区间内元素,返回True
print(r.ltrim('database',0,1))
while True:
# 如果列表中为空时,则返回None
result = r.brpop('database',1)
if result:
print(result)
else:
break
r.delete('database')
输出结果如下:
4 [b'redis', b',mongodb', b'mysql', b'sql'] b'sql' True (b'database', b',mongodb') (b'database', b'redis')
Python 操作 Hash 散列常用方法如下:
# 1、更新一条数据的value,若不存在时,则新建这条数据 hset(key, field, value) # 2、读取数据的指定字段属性,返回值为字符串类型 hget(key, field) # 3、批量更新字段属性,参数mapping为字典类型 hmset(key, mapping) # 4、批量读取数据的字段属性 hmget(key, fields) # 5、获取这条数据的所有属性字段和对应的值,返回值为字典类型 hgetall(key) # 6、获取这条数据的所有属性字段,返回值为列表类型 hkeys(key) # 7、删除这条数据的指定字段 hdel(key, field)
命令演示:
import redis
r = redis.Redis(host='127.0.0.1',port=6379,db=0)
# 设置一条数据
r.hset('user1','name','www.baidu.com')
# 更新数据
r.hset('user1','name','www.cdsy.xyz')
# 获取数据
print(r.hget('user1','name'))
# 一次性设置多个field和value
user_dict = {
'password':'123',
'gender':'M',
'height':'175cm'
}
r.hmset('user1',user_dict)
# 获取所有数据,字典类型
print(r.hgetall('user1'))
# 获取所有fields字段和所有values值
print(r.hkeys('user1'))
print(r.hvals('user1'))
输出结果:
b'www.cdsy.xyz' {b'name': b'www.cdsy.xyz', b'password': b'123', b'gender': b'M', b'height': b'175cm'} [b'name', b'password', b'gender', b'height'] [b'www.cdsy.xyz', b'123', b'M', b'175cm']
Python 操作 Set 集合常用方法如下:
#1、给name对应的集合中添加元素 sadd(name,values) e.g. r.sadd("set_name","tom") r.sadd("set_name","tom","jim") #2、获取name对应的集合的所有成员 smembers(name) e.g. r.smembers('set_name') #3、获取name对应的集合中的元素个数 scard(name) e.g. r.scard("set_name") #4、检查value是否是name对应的集合内的元素,返回值为True或False sismember(name, value) e.g. r.sismember('set_name','tom') #5、随机删除并返回指定集合的一个元素 spop(name) e.g. member = r.spop('set_name') #6、删除集合中的某个元素 srem(name, value) r.srem("set_name", "tom") #7、获取多个name对应集合的交集 sinter(keys, *args) e.g. r.sadd("set_name","a","b") r.sadd("set_name1","b","c") r.sadd("set_name2","b","c","d") print(r.sinter("set_name","set_name1","set_name2")) #输出:{b'b'} #8、获取多个name对应的集合的并集 sunion(keys, *args) e.g. r.sunion("set_name","set_name1","set_name2")