python学习之-- redis模块操作 集合和有序集合
redis 模块操作之 集合set和有序集合zset
Set 集合操作,不允许重复的列表
sadd(name,value):name对应的集合中添加元素
scard(name):获取name对应的集合中元素个数
sdiff(keys,*args):差集
sdiffstore(dest,keys,*args):差集存到新的地方
sinter(keys,*args):交集
sinterstore(dest,keys,*args):交集另外存储
sismember(name,value):判断是否有对应的值
smembers(name):获取集合所有成员
smove(src,dst,value):从一个value从src集合中移动到dst集合中
spop(name):从集合的右侧移除一个成员,并将其返回
srandmember(name,number):从name对应的集合中随机获取member个元素。
srem(name,value):在name对应的集合中删除某些值
sunion(keys,*args):并集
sunionstore(dest,keys,*args):并集另外存储
sscan(name,cursor=0,match=None,count=None)
sscan_iter(name,match=None,count=None)
同字符串的操作,用于增量迭代分批获取元素,避免内存消耗过大
添加举例:
r.sadd('sname','jack','bard') #添加数据
print(r.smembers('sname')) # 获取所有的值
有序集合:在集合的基础上,为每个元素排序,元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有
2个值,即:值和分数,分数专门用来做排序。
zadd(name,*arg,**kwargs):在name对应的有序集合中添加元素
zadd('zz',1,'n1',2,'n2') # 其中数字为权重值
获取值:zrange zz 0 -1
注意:当添加重复项是,修改的只是权重值,实际数据还是唯一的。
zrange zz 0 -1 withscores :可以同时显示数据和对应的权重值
zcard(name):获取集合元素的数量
zcount(name,min,max):获取集合中权重在min,max之间的个数
zincrby(name,value,amount):自增有序集合中name对应的分数
zrange(name,start,end,desc=False,withscores=False,score_cast_func=float)
按照索引范围获取name对应的有序集合的元素
start:有序集合索引的起始位置(非分数)
end:索引的结束位置(非分数)
desc:排序规则,默认按照分数从小到大排序
withscores:是否获取元素的分数
score_cast_func:对分数进行数据转换的函数
zrank(name,value):获取某个值在name对应的有序集合中的排序(从0开始)
zrangebylex(name,min,max,start=None,num=None)
当有序集合的所有成员都具有相同的分值时,有序集合的元素会根据成员的值
zrem(name,values):删除值
zremrangebyrank(name,min,max):根据排行范围删除,
zremrangebysore(name,min,max):根据分数范围删除
zremrangebylex(name,min,max):根据值返回删除。
zscore(name,value):获取name对应的有序集合中value对应的分数
zinterstore(dest,keys,aggregate=None):获取有序集合的交集,如果遇到相同值,则按照aggregate操作
aggregate值为:sum,min,max
zunionstore(dest,keys,aggregate=None):获取2个集合的并集,参数同上
zcan(name,cursor=0,match=None,count=None,score_cast_func=float)
# 同字符串相似,相较于字符串新增score_cast_func,用来对分数进行操作
python学习之-- redis模块操作 集合和有序集合的更多相关文章
- python学习之-- redis模块操作 LIST
redis 模块操作之 List List 操作,在内存中按照一个name对应一个List来存储. lpush(name,values):在name对应的list中添加元素,每个新的元素都添加到列表的 ...
- python学习之-- redis模块操作 string
redis 模块操作之--> String String:redis中的string在内存中按照一个key 对应一个 value来存储. 使用方法如下:set(name, value, ex=N ...
- python学习之-- redis模块操作 HASH
redis 操作 之 -Hash Hash 操作:hash在内存中的存储格式 name hash n1 ------> k1 -> v1 k2 -> v2 k3 -> v3hs ...
- python学习之-- redis模块管道/订阅发布
redis 模块操作剩余其他常用操作 delete(*names):删除任意的数据类型exists(name):检测redis的name是否存在keys(pattern='*'):根据模型获取redi ...
- python学习之-- redis模块基本介绍
数据缓存系统: 1:mongodb:是直接持久化,直接存储于硬盘的缓存系统 2:redis: 半持久化,存储于内存和硬盘 3:memcache:数据只能存储在内存里的缓存系统关于memcache 学习 ...
- Redis常用操作--------SortedSet(有序集合)
1.ZADD key score member [[score member] [score member] ...] 将一个或多个 member 元素及其 score 值加入到有序集 key 当中. ...
- python 学习笔记 redis操作
Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorte ...
- python对redis的常用操作 下 (无序集合,有序集合)
无序集合: 首先介绍增加,删除和获得所有元素的方法.我将会用第二部分来讨论集合的特殊操作: In [136]: x.sadd("challenge", 1,2,3,4,5,6,7, ...
- Python学习day18-常用模块之NumPy
figure:last-child { margin-bottom: 0.5rem; } #write ol, #write ul { position: relative; } img { max- ...
随机推荐
- Qt获取本机IP地址
Qt获取本机IP地址: Qt版本:4.8.6 #include <QtNetwork/QNetworkInterface.h> QString ipAddr; QList<QHost ...
- jacob的使用方法
网上一大堆你抄我的,我抄你的,但基本配置都没说清,做个笔记让后来的人少走冤枉路 1.下载最新的jacob,jdk版本一一对应,1.6对应jacob的1.16,1.7对应1.17.... 2.应用程序将 ...
- SQL Server时间类型datetime
SQL Server时间类型datetime 兼容ADO的COleDateTime. SQL datetime 日期和时间数据,可表示1753.1.1 至 9999.12.31的时间,精度为1/300 ...
- 洛谷P1724 东风谷早苗
题目描述 在幻想乡,东风谷早苗是以高达控闻名的高中生宅巫女.某一天,早苗终于入手了最新款的钢达姆模型.作为最新的钢达姆,当然有了与以往不同的功能了,那就是它能够自动行走,厉害吧(好吧,我自重).早苗的 ...
- 错误消息 This computer doesn't have VT-X/AMD-v enabled
在VirtualBox的Ubuntu虚拟机里试图本地安装Kyma(一个基于Kubernetes的开源框架)时,遇到下面的错误信息: E0827 11:19:38.972489 3093 start.g ...
- mysql 增删查改
非关系型数据库关系型数据库Oracle mysql sqlserver db2 Postgresql Sqlite access sqlserver 微软db2 ibm================ ...
- Open Cascade:使用鼠标画线
Open Cascade:使用鼠标画线 在View类文件中创建以下代码: 1.创建鼠标消息: afx_msg void OnLButtonDown(UINT nFlags, CPoint point) ...
- spring mvc poi excel
Util类 package com.common.util; public class ExportUtil { private XSSFWorkbook wb = null; private XSS ...
- mysql中使用load data infile导入数据的用法
有时需要将大量数据批量写入数据库,直接使用程序语言和Sql写入往往很耗时间,其中有一种方案就是使用mysql load data infile导入文件的形式导入数据,这样可大大缩短数据导入时间. LO ...
- MySQL之federated
由于夸服务器查询的限制,federated能够使得所有的表像是在同一台服务器上查询 (show engines-->no-->在my.ini里面添加fedrated) 经过测试,在开启fe ...