1、先看下redis的连接

import redis

# 连接服务端
r = redis.Redis(host="127.0.0.1",port=6379)

#获取所有的key值
print(r.keys())


#获取某个键的value
print(r.get("name"))

# 设置一个键值对
r.set("name","ddd",ex=3)

 

2、在看下redis的连接池,创建一个连接池,并且连接该连接池

connect_pool = redis.ConnectionPool(host="1.1.1.1",port=6379)

r = redis.Redis(connection_pool=connect_pool)

r.set("age",23,ex=2)
print(r.get("age"))

 

3、下面是redis的重点,操作包括dict,list,set,有序集合,hash的操作

# 3、操作
# 过期时间
#   ex 单位是秒钟
#   px 单位是毫秒
#   nx 如果设置为True,则只有name不存在时候,当前set操作才执行
#   xx 如果设置为True,则治愈后name存在的时候,当前set操作才执行

r.setnx()
#设置值,只有name不存在的时,执行设置操作

#批量get值
r.mget()

#批量设置值
r.mset()

#设置新的值然后获取老的值
r.getset()


# #获取value的子序列,根据字节提取,非字符
#    参数:
#         name Redis的name的值
#         start  起始位置字节
#         end    结束位置字节
r.getrange(key="name",start=1,end=2)


#修改字符串的内容,从指定的字符串索引开始向后替换,如果新的值过长,则向后添加
  # 参数:
  #       offset 字符串的索引,字节,一个汉字3个字节
  #       value   要设置的值
# r.setrange(name,offset,value)
# 比如name=12345
# r.setrange(name,2,"abcde")
# 最后name的值为1abcde



#对name对应的二进制表示的位进行操作
   # 参数
   #     name      redis的name
   #     offect    位的索引(将值变换成二进制后进行索引)
   #     value     值只能是1或者0
   #

# r.setbit(name,7,0)
#把name的value值用SCSI码表示,然后把第七位替换为0或者1
# r.setbit()


# 查看第6位的SCSI码数,从1开始数
# r.getbit("name",6)


#看一个例子,比如要统计uv,就是每天有多少用户访问我们的网站
# r.setbit("uv_count",id,1)

# r.setbit("uv_count",1,1)
# r.setbit("uv_count",2,1)
# r.setbit("uv_count",4,1)
# print(r.bitcount("uv_count"))

#先把uv_count的值设置为0,然后每个用户都有自己的id,那么每个用户过来,id为1,我们就把第1位设置为1,id为100,我们就把
#第100位设置为1,bitcount的方法就是统计value中的1的数量


# 返回value的长度,一个汉字是3个字节
print(r.strlen("name"))


#如果name存在,则自加1,如果name不存在,则创建name并赋值为1,统计pv的时候有用
# r.incr("name",1)

#和incr的效果一样,不过这个是自减
# r.decr()


#对name的value的值后面追加内容,追加的内容为aaaaa,就是拼接字符串
r.append("name","aaaa")



#Hash操作,存dict

# name             hash
#
# name1 ----------> k1-->v1
#                   k2-->v2
#                   k3-->v3
#
#
#
#
# name2 ----------> k1-->v1
#                   k2-->v2
#                   k3-->v3



# 单独设置hash
r.hset("stu_info","stu1","a")
r.hset("stu_info","stu2","b")
r.hset("stu_info","stu3","c")

#批量设置hash
r.hmget("stu_info",{"stu4":"d","stu5":"e","stu6":"f"})

# 获取指定的hash值
r.hget("stu_info","stu3")

#获取全部的hash值
r.hgetall("stu_info")


#获取name对应的hash中的键值对的个数
r.hlen()


#获取name对应的hash中所有的key的值
r.hkeys()


#获取name对应的hash中的所有的value的值
r.hvals()

#检测name对应的hash是否存储在当前传入的key
# r.hexists(name,value)


#将name对应的hash中指定的key键值对删除
# r.hdel()


#给name对应的hash中的key的value的值自加1
r.hincrby()




#list操作,存list

#添加元素,从左边push,从右边pus

r.lpush()
r.rpush()

#获取list的值,需要加一个范围
r.lrange("")

#获取长度
r.llen()


# 插入值
# r.linsert(name,where,refvalue,value)

# where = before|after
# refvalue  list中某个元素的值,在这个值后面获取前面插入一个值,在找到的第一个元素前面或者后面
# value    插入的值



# r.ltrim(name,start,end)
#在name对应的列表中移除没有在start-end索引之间的值



#set操作,集合操作,set集合就是不允许重复的列表

#最终的list中只有一个1和一个3,为name对应的集合添加元素
r.sadd("set_list","1","3","1")

#查看某个name的集合的元素,但是会带一个优先级
r.sscan()

#获取name对应的集合的元素的个数
r.scard()


#比较2个都在redis中的set的差集,求在set1对应的集合,且不在set2对应的集合的值的集合
r.sdiff("set1","set2")


#把a和b对应的集合存到c对应的集合中
r.sdiffstore("a","b","c")


#求name为a对应的集合和name为b对应的集合的交集
r.sinter("a","b")




#判断value是否在name对应的集合中

# r.sismember(name,value)



#获取某个name对应的集合的元素
r.smembers()



#将name为a对应的集合中的元素"c"移到name为b对应的集合中,a中就没有这个原始怒
r.smove("a","b","c")



#从集合的右侧(尾部)移除第一个成员,并将其返回
r.spop()

#删除随机的h获取number个元素
r.srandmember("name",20)


##删除某个值
r.srem()


#获取多个name对应的集合的并集
r.sunion()


#获取b、c、d。。。。。的集合的并集,并将结果保存到a对应的集合中
# r.sunionstore("a","b","d","d".....)


#有序集合的操作
#有序集合,在集合的基础上,为每个元素排序,元素的排序需要根据另外一个值来决定,
#元素有2个值,即值和分数,分数专门用来做排序

#值为a,分数为10,值为b,分数为4,分数小的靠前
r.zadd("name","a",10,"b",4)

#查看有序集合的元素的值
r.zscan()

#获取有序集合的长度
r.zcard()


#获取有序集合中分数在[min,max]之间的个数
r.zcount()

#可以自增有序集合中某个元素的分数
r.zincrby()


#获取name对应的集合中分数在34和59的元素
r.zrangebyscore("name",34,59)


#删除某个k
r.delete()


#判断某个k是否存在
r.exists()

#给某个k设置超时时间
r.expire()


#g重命名某个k的名字
r.rename()


#将name中的某个值移到db中
# r.move(name,db)



#随机获取个name的值,但是不删除
r.randomkey()


#获取name对应的值类型
r.type()


#redis默认有16个库
# select 2,切换到库2中

  

 

posted on 2017-09-09 16:42  bainianminguo  阅读(1013)  评论(0编辑  收藏  举报