redis的使用和一些简单的方法
import redis
from redis_pool import Pool
###以下三种方式三选一都可以连接到库中###
# 通过url的方式换库(从默认换到第二个库)
conn=redis.Redis.from_url('redis://127.0.0.1:6379/2')
# 连接到连接池子(池子中可以放入许多redis库)
# conn=redis.Redis(connection_pool=Pool)
# 至于池子可以这么写Pool=redis.ConnectionPool(host='127.0.0.1',port=6379,max_connections=2**31)
# 最基础的连接redis的方式
# conn=redis.Redis(host='localhost', port=6379,db=0)
#######字符串########
# * conn.set('key','value', #一次储存一个,下面为可选项
# 'ex', #设置以秒为单位的超时时间
# 'px', #设置以毫秒为单位的超时时间
# 'nx', #当值为True判断key是否存在,如果不存在则存入
# 'xx') ##当值为True判断key是否存在,如果存在则修改
# * conn.get('key') #一次获取一个
# * conn.mset({'key1':'value1','key2':'value2',}) #一次储存多个
# * conn.mget('key','key2') #一次获取多个(可以采用列表的形式)
# conn.getset('key','value') #获取数据库中对应的value值并更改value
# conn.getrange('key',start,end) # 获取对应值中的对应字符串,
# 例name=yhwu conn.getrange('name',0,2) #结果为yhw
# conn.setrange('key',start,replace) #从对应值中的第几个位置开始替换,全部替换上
# setbit,getbit,bitcount,bitop因为是对二进制做出操作的而python中二进制操作较少所以不介绍了
# conn.strlen('key') #获取对应值的长度
# * conn.incr('key',num) #对应值+num(必须是数字,不然会报错)
# * conn.decr('key',num) #对应值-num(必须是数字,不然会报错)
# * conn.append('key','字符串') #对应值后追加字符串
#注:'*'为以后可能常用的命令
#######哈希########
# * conn.hset('name','key','value') #哈希简单来说就是字典,name是字典名字,key,value是字典的值
# * conn.hget('name','key') # 取出对应字典里面的value值
# * conn.hmset('name',{'key1':'value1','key2','value2'}) #一次性往字典里储存多个值
# * conn.hmget('name','key1','key2') #一次性从字典里出多个值(key1,key2可以采用列表的形式)
# conn.hgetall('name') #取出对应字典里面的所有值
# conn.hlen('name') #字典里的键值对数量
# conn.hkey('name') # 字典里的所有key值
# conn.hvalue('name') #字典里的所有value值
# conn.hexists('name','key') #判断字典里是否有key值
# conn.hdel('name','key1') # 删除key,value(可以用列表方式删除多个值)
# * conn.hincrby('name','key',num) # 字典里的对应value值+num
# conn.hincrbyfloat('name','key',num) # 字典里的对应value值+num(这里为float类型)
# * conn.hscan_iter('name',num) #一次性从字典中取出相应数量的值,从而不会因量过大而撑爆服务器
########列表########
# * conn.lpush('name',value1,value2) #从左往右开始插入name是列表名字,后面是列表值
# conn.rpush('name',value1,value2) #从右往左开始插入
# conn.lpushx('name',value) #判断列表是否存在,存在则插入(有l就有r这后面就不写了)
# * conn.llen('name') #列表的元素个数
# conn.linsert('name',
# where, #只有before,after 往前还是往后插
# refvalue, #在哪个值
# value) #插入什么值
# conn.lset('name',
# index, # 索引位置
# value) # 插入某个值
# conn.lrem('name',
# num, #删除的数量 num=0全删 num<0从后往前 num>0从前往后
# value) # 删除的值 注意是删除的值不是索引!!
# * conn.lpop('name') # 删除左边第一个元素
# conn.rpop('name') # 删除右边第一个元素
# conn.lindex('name',index) #获取对应索引的值
# * conn.lrange('name',start,end) #获取对应索引的所有值
# conn.ltrim('name',start,end) # 一次性删除没有在对应索引的值
# conn.rpoplpush(src,#将列表(最右边的值)
# dst)#加入这个列表
# * conn.blpop('name', #当值没有时会卡在那,会等下次放值时才会执行
# timeout) #这个是卡的时间,卡多少时间
#######管道#########
# 建立管道 transction设置为事务(未开始)
# pipe = conn.pipeline(transaction=True)
# 开始存储语句
# pipe.multi()
# 存储要执行的语句
# pipe.set('key','value')
# # 执行语句
# pipe.execute()
########公共操作########
# conn.delete('key') #只要redis中有就可以删
# conn.exists('key') #判断key值是否存在
# conn.keys() #索取里面所有的name值(括号内可以写正则过滤)
# conn.expire('name',time) #为其设置过期时间
# conn.rename('name','new_name') #重命名
# conn.move('name',db) #将其移动到某库
# conn.randomkey() #随机获取一个name
# conn.type('name') #获取其数据类型
# 在django中可以使用以上自定义的池子,也可以用为我们提供方便的django-redis
# 第一步在设置中配置
# CACHES = {
# "default": {
# "BACKEND": "django_redis.cache.RedisCache",
# "LOCATION": "redis://127.0.0.1:6379",
# "OPTIONS": {
# "CLIENT_CLASS": "django_redis.client.DefaultClient",
# "CONNECTION_POOL_KWARGS": {"max_connections": 100}
# # "PASSWORD": "123",
# }
# }
# }
# 第二步在相应位置
# from django_redis import get_redis_connection
# 连接上连接池
# conn = get_redis_connection('default')
# 连接上连接池后开始写关于redis的操作
# print(conn.hgetall('xxx'))