第二百九十八节,python操作redis缓存-Set集合类型,可以理解为不能有重复元素的列表

python操作redis缓存-Set集合类型,可以理解为不能有重复元素的列表

 

sadd(name,values)name对应的集合中添加元素

 

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('adc8868','123')                                         #sadd(name,values)name对应的集合中添加元素

f = r.smembers('adc8868')                                       #获取name对应的集合的所有成员
print(f)
#返回
#{b'123'}

 

 

scard(name)获取name对应的集合中元素个数

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('adc8868','123')                                         #sadd(name,values)name对应的集合中添加元素

f = r.scard('adc8868')                                          #scard(name)获取name对应的集合中元素个数
print(f)
#返回
#1

 

sdiff(keys, *args)在第一个name对应的集合中且不在其他name对应的集合的元素集合

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('adc8861','123','456')                                   #sadd(name,values)name对应的集合中添加元素
r.sadd('adc8862','123','456','789')

f = r.sdiff('adc8862','adc8861')                                #sdiff(keys, *args)在第一个name对应的集合中且不在其他name对应的集合的元素集合
print(f)
#返回
#{b'789'}

 

sdiffstore(dest, keys, *args)获取第一个name对应的集合中且不在其他name对应的集合,再将其新加入到dest对应的集合中

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('adc8861','123','456')                                   #sadd(name,values)name对应的集合中添加元素
r.sadd('adc8862','123','456','789')

f = r.sdiffstore('adc','adc8862','adc8861')                    #sdiffstore(dest, keys, *args)获取第一个name对应的集合中且不在其他name对应的集合,再将其新加入到dest对应的集合中
print(f)

n = r.smembers('adc')                                          #获取name对应的集合的所有成员
print(n)
#返回
# 1
# {b'789'}

 

sinter(keys, *args)获取多个集合与第一个集合里交集的数据,也就是相同的数据

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.sinter("rdi1","rdi2")                                     #sinter(keys, *args)获取多个集合与第一个集合里交集的数据,也就是相同的数据
print(n)

#返回
#{b'123', b'456'}

 

sinterstore(dest, keys, *args)获取多个集合与第一个集合里交集的数据,也就是相同的数据,在将其加入到dest对应的集合中

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.sinterstore('adc',"rdi1","rdi2")                           #sinterstore(dest, keys, *args)获取多个集合与第一个集合里交集的数据,也就是相同的数据,在将其加入到dest对应的集合中
print(n)

n = r.smembers('adc')                                          #获取name对应的集合的所有成员
print(n)
#返回
# 2
# {b'123', b'456'}

 

sismember(name, value)检查value是否是name对应的集合的成员

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.sismember("rdi1",'851')                           #sismember(name, value)检查value是否是name对应的集合的成员
print(n)

#返回
#True

 

smembers(name) 获取name对应的集合的所有成员

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.smembers("rdi1")                           #smembers(name) 获取name对应的集合的所有成员
print(n)

#返回
#{b'123', b'851', b'456'}

 

smove(src, dst, value)将某个成员从一个集合中移动到另外一个集合

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.smove("rdi1",'rdi2','851')                           #smove(src, dst, value)将某个成员从一个集合中移动到另外一个集合
print(n)

#返回
#True

 

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

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.spop("rdi1")                           #spop(name)从集合的右侧(尾部)移除一个成员,并将其返回
print(n)

#返回
#b'851'

 

srandmember(name, numbers)从name对应的集合中随机获取 numbers 个元素

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.srandmember("rdi1",number=2)                           #srandmember(name, numbers)从name对应的集合中随机获取 numbers 个元素
print(n)

#返回
#[b'851', b'123']

 

srem(name, values)在name对应的集合中删除某些值

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.srem("rdi1",'456')                           #srem(name, values)在name对应的集合中删除某些值
print(n)

#返回
#1

 

sunion(keys, *args)获取多个name对应的集合的并集,并集后相同的数据只显示一个

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

n = r.sunion("rdi1",'rdi2')                           #sunion(keys, *args)获取多个name对应的集合的并集,并集后相同的数据只显示一个
print(n)

#返回
#{b'456', b'123', b'789', b'851'}

 

sunionstore(dest,keys, *args)获取多个name对应的集合的并集,并集后相同的数据只取一个,并将结果保存到dest对应的集合中

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

r.sunionstore('adc',"rdi1",'rdi2')               #sunionstore(dest,keys, *args)获取多个name对应的集合的并集,并集后相同的数据只取一个,并将结果保存到dest对应的集合中
n = r.smembers("adc")                           #smembers(name) 获取name对应的集合的所有成员
print(n)

#返回
#{b'456', b'851', b'123', b'789'}

 

sscan(name, cursor=0, match=None, count=None)同字符串的操作,用于增量迭代分批获取元素,避免内存消耗太大【推荐使用下面那个方法】
  name,redis的name
  cursor,游标(基于游标分批取获取数据)
  match,匹配指定key,默认None 表示所有的key
  count,每次分片最少获取个数,默认None表示采用Redis的默认分片个数
  如:
  第一次:cursor1, data1 = r.sscan('name', cursor=0, match=None, count=None)
  第二次:cursor2, data2 = r.sscan('name', cursor=cursor1, match=None, count=None)
  ...
  直到返回值cursor的值为0时,表示数据已经通过分片获取完毕

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

#sscan(name, cursor=0, match=None, count=None)用于增量迭代分批获取元素,避免内存消耗太大
cursor1, data1 = r.sscan('rdi1',cursor=0,match='*1',count=None)       #获取name对应的元素,匹配以1结尾的元素
print(cursor1, data1)                                                 #返回两个值,第一个是获取的游标位置,第二个是获取到的数据

cursor2, data2 = r.sscan('rdi1',cursor=cursor1,match='*2',count=None)    #第二次获取,游标使用第一次返回的游标位置,使其向后继续
print(cursor2, data2)


#返回
#0 [b'851']
#0 []

 

sscan_iter(name, match=None, count=None)用于增量迭代分批获取元素,避免内存消耗太大【推荐】
  name,redis的name
  match,匹配指定key,默认None 表示所有的key
  count,每次分片最少获取个数,默认None表示采用Redis的默认分片个数

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import redis                #导入操作redis模块

pool = redis.ConnectionPool(host='127.0.0.1', port=6379)  #配置连接池连接信息

r = redis.Redis(connection_pool=pool)                           #连接连接池
r.sadd('rdi1','123','456','851')                                #sadd(name,values)name对应的集合中添加元素
r.sadd('rdi2','123','456','789')

#sscan_iter(name, match=None, count=None)用于增量迭代分批获取元素,避免内存消耗太大
n = r.sscan_iter('rdi1',match='*1',count=None)       #获取name对应的元素,匹配以1结尾的元素
print(n)                                             #返回获取到的数据对象,需要循环

for i in n:
    print(i)                                         #循环出获取到的数据


#返回
# <generator object StrictRedis.sscan_iter at 0x0000023F18C94570>
# b'851'

 

posted @ 2017-07-06 16:33  林贵秀  阅读(787)  评论(0编辑  收藏  举报