Python与Redis交互教程
- 实践: python 与 Redis
==========================================
其他教程链接1个
Redis 官方推荐的 Python客户端是 redis-py.
5.1 安装
<pre class="python">```
pip3 install redis
cookies
补充内容: Ubuntu下redis开启远程连接
打开redis配置:sudo vi /etc/redis/redis.conf
注释掉"bind 127.0.0.1",或者修改为"bind 0.0.0.0"
重启redis服务:sudo /etc/init.d/redis-server restart
5.2 连接数据库
导入模块
<pre class="python">```
# 导入 redis-py:
import redis
# 默认创建连接地址 127,0,0,1, 端口 6379
r = redis.Redis
r = redis.StrictRedis()
# 也可以显式指定需要连接的地址
r = redis.Redis(host='127.0.0.1', port=6379, db=0)
r = redis.StrictRedis(host='127.0.0.1', port=6379, db=0)
r.set('fo', 'hello world')
print(r.get('fo'))
# b'hello world'
<pre class="python">```
import redis
# 连接redis加个decode_responses=True,这样出来的直接是中文,不需要decode
r = redis.Redis(decode_responses=True)
r = redis.Redis('127.0.0.1', 6379, 0,decode_responses=True)
r.set('fooo', '早上好')
print(r.get('fooo'))
# 早上好
事务和管道
事务
<pre class="python">```
pipe = r.pipeline()
pipe.set('foo','far')
pipe.get('foo')
result = pipe.execute()
print(result)
# [True, b'far']
管道
<pre class="python">```
# transation = False
pipe = r.pipeline().set('foa','foo').get('foo').execute()
print(pipe)
# [True, b'far']
5.3 简单操作
在python3下, 首先导入redis
<pre class="python">```
>>> from redis import Redis,StrictRedis
>>> r = Redis(decode_responses=True)
5.3.1 String字符串操作
语法作用示例r.set(key, value)给key赋值为valuer.set('key','value')
Out[22]: Truer.get(key)返回数据库中key的valuer.get('key')
Out[23]: 'value'r.getset(key, value)给key赋值为value, 并返回上次的value; 若无值, 则不返回r.getset('key','vakue')
Out[24]: 'value'r.mget(keys, *args)返回多个key对应的valuer.mget('name','key')
Out[25]: [None, 'vakue']r.setnx(key,value)当key不存在才设置value, 设置成功返回True, 当key存在返回False,不更改valuer.setnx('foo','bar')
Out[26]: Truer.setex(key,time,value)设置key的value, 指定有效期为timer.setex('fo',1,'jane')
Out[28]: Truer.setrange(key, offset, value)设置key的value值的子字符串r.setrange('name',6,'world')
Out[31]: 11r.mset(**kargs)批量赋值r.mset({'n1':'john','n2':'kang'})
Out[33]: Truer.msetnx(**kargs)key不存在才批量赋值r.msetnx({'n3':'n33','n4':'n44'})
Out[34]: Truer.incr(key, amount=1)设置key的value增值操作, 默认1, key不存在则被创建并设为 amount, amount 可以为负数,表示减值r.incr('age',1)
Out[36]: 1
r.incr('age',3)
Out[37]: 4r.decr(key,amount=1)设置key的value减值操作, 默认1, key不存在则被创建并设置为-mount, amount可以为负值, 表示增值r.decr('score',2)
Out[38]: -2r.append(key,value)为key的值附加valuer.append('nick','popo')
Out[40]: 6r.substr(key,start,end=-1)返回key的value子串, end默认为-1,包含endr.substr('nick',0)
Out[42]: 'OKpopo'r.getrange(key,start,end)返回key的value值从start到end子串,包含endr.getrange('nick',1,4)
Out[43]: 'Kpop'#### 5.3.2 Key操作
语法作用示例r.exists(key)判断一个key是否存在, 存在返回True, 解码为1,不存在返回False, 解码为0r.exists('score')
Out[8]: 1r.delete(key)删除一个key,r.delete('nick')
Out[9]: 1r.type(key)判断一个key的类型r.type('age')
Out[10]: 'string'r.keys(pattern)获取所有符合规则的keyr.keys('a*')
Out[10]: ['age', 'ag']r.randomkey()获取随机的一个keyr.randomkey()
Out[10]: 'key'r.rename(key,newkey)将key重命名r.rename('age','height')
Out[10]: Truer.dbsize()获取当前数据库中key的数目r.dbsize()
Out[5]: 5r.expire(key,time)设定key的过期时间, 单位秒r.expire('scor',2)
Out[12]: Truer.ttl(key)获取key的过期时间, 单位秒, -1为永久不过期r.ttl('score')
Out[14]: -1r.move(key,db)将key移动其他数据库r.move('score',2)
Out[15]: Truer.flushdb()删除当前选择数据库中的所有keyr.flushdb()
Out[20]: Truer.flushall()删除所有数据库中的所有keyr.flushall()
Out[21]: True#### 5.3.3 List操作
语法作用示例r.rpush(key,*values)在key尾部(右边)添加值为value的元素, key传多个, 返回list元素个数r.rpush('list',1,2,3)
Out[48]: 3r.lpush(key,*values)在key头部添加值为value的元素, 可以传多个,返回list元素个数r.lpush('list',0)
Out[49]: 4r.llist(key)返回key的长度r.llen('list')
Out[50]: 4r.lrange(key,start,end)返回key中start~end之间的元素, 包含endr.lrange('list',0,-1)
Out[52]: ['0', '1', '2', '3']r.ltrim(key,start,end)截取key, 保留索引为start至end的内容r.ltrim('list',1,3)
Out[54]: Truer.lindex(key,index)返回key的index位置的元素, 越界则没有返回值r.lindex('list',2)
Out[58]: '3'r.lset(key,index,value)给key的index位置赋值, 越界则报错r.lset('list',2,6)
Out[61]: Truer.lrem(key,count,value)删除key中 count 个值为 value 的元素, 返回删除个数r.lrem('list',2,6)
Out[64]: 1r.lpop(key)删除并返回key的首元素(左边)r.lpop('list')
Out[66]: '1'r.rpop(key)删除并返回key的尾元素(右边)r.rpop('list')
Out[68]: '2'r.blpop(key,timeout=0)删除并返回key的首元素, 如果key为空, 则会一直阻塞等待, 返回元组,(key,value)r.blpop('list')
Out[69]: ('list', '123')r.brpop(key,timeout=0)删除并返回key的尾元素, 如果key为空, 则会一直阻塞等待, 返回元组,(key,value)r.brpop('list')
Out[71]: ('list', '1')r.rpoplpush(key,newkey)删除并返回key的尾元素, 并将元素添加到, newkey的头部r.rpoplpush('list','list1')
Out[73]: '2'#### 5.3.4 Set操作
语法作用示例r.sadd(key,*values)向key中添加元素, 可以添加多个, 返回插入元素个数r.sadd('tags','Book','Tea')
Out[77]: 2r.srem(key,*values)从key中删除元素, 可以删除多个, 返回成功删除的个数r.srem('tags','Book','Tea')
Out[78]: 2r.spop(key)随机删除并返回key中的一个元素r.spop('tags')
Out[79]: 'Coffee'r.smove(key,newkey,value)从key中移除元素并添加到newkey中r.smove('tags','news','Book')
Out[81]: Truer.scard(key)返回key中的元素个数r.scard('tags')
Out[82]: 2r.sismember(key,value)测试value是否在key中, 在返回True, 不在返回Falser.sismember('tags','Tea')
Out[84]: Truer.sinter(keys, *args)返回交集, 没有交集返回空集r.sinter('tags','news')
Out[85]: {'Tea'}r.sinterstore(dset,keys,*args)求交集, 并将交集保存到dset集合中, 返回dset元素个数r.sinterstore('dset','tags','news')
Out[93]: 1r.sunion(keys.*args)返回并集r.sunion('tags','tag2','tag3')
Out[97]: {'Coffee', 'Tea'}r.sunionstore(dset,keys,*args)求并集, 并将并集保存到dset中, 返回并集的元素个数r.sunionstore('log','tags','news')
Out[99]: 3r.sdiff(key,*args)求差集, 并返回在key中, 但不在*args中的元素集合r.sdiff('tags','news')
Out[100]: {'Coffee'}r.sdiffstore(dset,key,*args)求差集, 并将差集保存在dset中, 返回差集个数r.sdiffstore('dset','tags','news')
Out[105]: 1r.smembers(key)返回key中所有元素r.smembers('tags')
Out[107]: {'Coffee', 'Tea'}r.srandmember(key)随机返回key中的一个元素, 但不删除元素r.srandmember('tags')
Out[108]: 'Coffee'#### 5.3.5 Sorted Set操作
语法作用示例r.zadd(key,**kargs)向key中添加元素, 如果元素已存在, 则更新其scorer.zadd('grade',{'Bob':80,'Mike':61})
Out[7]: 2r.zrem(key,*values)删除key中的元素r.zrem('grade','Mike','Bob')
Out[11]: 2r.zincrby(key, amount=1,value,)如果在key中已经存在元素value,则该元素的score增加amount,否则向该集合中添加该元素,其score的值为amountr.zincrby('grade',-2, 'Bob')
Out[13]: -2.0r.zrank(key,value)返回key中元素的排名下标 (按score从小到大)r.zrank('grade','Bob')
Out[18]: 1r.zrevrank(key,value)返回key中元素的倒数排名下标 (按score从大到小)r.zrevrank('grade','Bob')
Out[20]: 0r.zrevrange(key,start,end, withscores=False)返回key中的index从start到end的所有元素 (按score从大到小排序)r.zrevrange('grade',0,-1)
Out[21]: ['Bob', 'Mike']r.zrangebyscore( key,min,max, start=None,
num=None, withscores=False)返回key中score在min到max之间的元素r.zrangebyscore('grade',60,90)
Out[27]: ['Kang', 'Mike', 'Bob']r.zcount(key,min,max)返回key中score在min到max之间的数量r.zcount('grade',60,90)
Out[31]: 3r.zcard(key)返回key中元素个数r.zcard('grade')
Out[34]: 4r.zremrangebyrank( key,min,max)删除并返回key中排名在min到max之间的元素个数r.zremrangebyrank('grade',0,1)
Out[35]: 2r.zremrangebyscore( key,min,max)删除并返回key中score在给定区间的元素个数r.zremrangebyscore('grade',60,90)
Out[36]: 1#### 5.3.5 Hash操作
语法作用示例r.hset(key,field,value)向key中添加映射, 如果已存在, 则更新,r.hset('price','cake',5)
Out[41]: 1r.hsetnx(key,field,value)向key中添加映射, 如果field不存在, 如果存在不更新r.hsetnx('price','apple',5)
Out[45]: 1r.hget(key, field)返回key中映射对象的valuer.hget('price','cake')
Out[48]: '6'r.hmget(key,fields,*args)返回key中各个映射对应的valuer.hmget('price','cake','apple')
Out[53]: ['6', '5']r.hmset(key,mapping)向key中批量添加映射r.hmset('price',{'orange':3,'banana':2})
Out[54]: Truer.hincrby(key,field, amount=1)向key中映射的value增加amountr.hincrby('price','orange',2)
Out[56]: 5r.hexists(key,field)判断key中是否存在键名为field的映射r.hexists('price','orange')
Out[57]: Truer.hdel(key,*fields)删除key中field的映射r.hdel('price','orange')
Out[60]: 1r.hlen(key)从key中获取映射个数r.hlen('price')
Out[61]: 3r.hkeys(key)从key中获取所有映射键名r.hkeys('price')
Out[62]: ['cake', 'apple', 'banana']r.hvals(key)从key中获取所有映射键值r.hvals('price')
Out[63]: ['8', '5', '2']r.hgetall(key)从key中获取所有映射键值对r.hgetall('price')
Out[64]: {'cake': '8', 'apple': '5', 'banana': '2'}#### RedisDump
- redis-load
将数据导入到数据库中
- redis-dump
将数据库信息导出