向爬虫而生---Redis 基石篇4 <拓展Set>

2024-01-03 09:44

本文主要是介绍向爬虫而生---Redis 基石篇4 <拓展Set>,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

延伸上一篇:https://blog.csdn.net/m0_56758840/article/details/135349796

挖一挖集合的一些骚操作~

正文:

基本操作:

集合是Redis中的一种数据类型,它具有以下几个基本概念和特性:无重复、无序和集合间的运算。下面是几个常用的集合命令,以及一些案例来说明:

  1. sadd key <value>:将一个或多个成员添加到集合中。

    127.0.0.1:6379> sadd myset 1 2 3
    (integer) 3
    127.0.0.1:6379> sadd myset 3 4
    (integer) 1
    

    在上述示例中,我们使用sadd命令将元素1、2、3添加到名为myset的集合中。首次添加时,返回值为3,表示成功添加了3个成员。然后,我们再次添加元素3和4,但由于集合不允许重复成员,所以返回值为1,表示只有元素4被成功添加到集合中。

  2. srem key <value>:从集合中移除一个或多个成员。

    127.0.0.1:6379> srem myset 2 3
    (integer) 2
    

    在上述示例中,我们使用srem命令从名为myset的集合中移除元素2和3。返回值为2,表示成功移除了2个成员。

  3. scard key:计算集合的大小(基数)。

    127.0.0.1:6379> scard myset
    (integer) 2
    

    在上述示例中,我们使用scard命令计算名为myset的集合的大小。返回值为2,表示集合中有2个成员。

  4. sismember key <value>:判断指定成员是否属于集合。

    127.0.0.1:6379> sismember myset 1
    (integer) 1
    127.0.0.1:6379> sismember myset 5
    (integer) 0
    

    在上述示例中,我们使用sismember命令判断元素1和5是否属于集合。返回值为1表示元素1属于集合,返回值为0表示元素5不属于集合。

  5. srandmember key <count>:从集合中随机获取一个或多个成员。

    127.0.0.1:6379> srandmember myset 2
    1) "1"
    2) "4"
    

    在上述示例中,我们使用srandmember命令从名为myset的集合中随机获取2个成员。返回的成员是随机选择的,每次执行可能得到不同的结果。

  6. spop key:从集合中随机弹出一个成员。

    127.0.0.1:6379> spop myset
    "4"
    

    在上述示例中,我们使用spop命令从名为myset的集合中随机弹出一个成员。弹出的成员是随机选择的,并从集合中移除。

  7. smembers key:获取集合中的所有成员。

    127.0.0.1:6379> smembers myset
    1) "1"
    

    在上述示例中,我们使用smembers命令获取名为myset的集合中的所有成员。(容易造成阻塞,慎用)

通过使用这些集合命令,我们可以对集合进行添加、删除、统计等操作,还可以判断成员是否属于集合,并从集合中随机获取成员或弹出成员。这些命令非常适用于需要对成员进行唯一性管理、随机选择或进行集合间的运算等场景。.


集合的关键用法:

集合的关键用法中,包括了三个关于集合间运算的命令:sdiff(差集)、sinter(交集)、sunion(并集)。

sdiff命令:

  • sdiff key1 [key2 ...],返回给定集合之间的差集。
  • 差集是指在第一个集合中存在,但在其他集合中不存在的成员。
# 创建两个集合
127.0.0.1:6379> sadd set1 1 2 3 4
(integer) 4
127.0.0.1:6379> sadd set2 3 4 5 6
(integer) 4# 计算集合的差集
127.0.0.1:6379> sdiff set1 set2
1) "1"
2) "2"

使用sadd命令创建了两个集合set1set2,分别包含了不同的成员。然后,通过使用sdiff命令计算set1set2之间的差集,即在set1中存在但在set2中不存在的成员,返回结果为12

sinter命令:

  • sinter key1 [key2 ...],返回给定集合之间的交集。
  • 交集是指在所有给定集合中都存在的成员。
# 创建两个集合
127.0.0.1:6379> sadd set1 1 2 3 4
(integer) 4
127.0.0.1:6379> sadd set2 3 4 5 6
(integer) 4# 计算集合的交集
127.0.0.1:6379> sinter set1 set2
1) "3"
2) "4"

使用sadd命令创建了两个集合set1set2,分别包含了不同的成员。然后,通过使用sinter命令计算set1set2之间的交集,即在set1set2中都存在的成员,返回结果为34

sunion命令:

  • sunion key1 [key2 ...],返回给定集合之间的并集。
  • 并集是指将所有给定集合中的成员合并起来,去除重复的成员。
# 创建两个集合
127.0.0.1:6379> sadd set1 1 2 3 4
(integer) 4
127.0.0.1:6379> sadd set2 3 4 5 6
(integer) 4# 计算集合的并集
127.0.0.1:6379> sunion set1 set2
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
6) "6"

使用sadd命令创建了两个集合set1set2,分别包含了不同的成员。然后,通过使用sunion命令计算set1set2之间的并集,即将set1set2中所有的成员合并起来,去除重复的成员,返回结果为123456


应用层面:

在Redis的集合数据类型中,可以应用于许多不同的开发场景,例如:

1.标签系统:
集合可以作为标签的容器,用于对数据进行标记和分类。例如,可以将用户标记为"管理员"、"VIP"、"新用户"等,以便更轻松地进行用户分类和查询。 
  •         sadd: 添加标签到集合中。
  •         srem: 从集合中删除指定的标签。
  •         smembers: 获取集合中的所有标签。       
2.实时统计:
通过将数据元素存储在集合中,可以进行实时的统计和计数操作。例如,可以使用集合记录每天访问网站的独立IP,并通过计算集合的大小获取独立访客数。        
  •         sadd: 将数据元素添加到集合中,用于记录每个数据元素的出现。
  •         scard: 获取集合的大小,可用于统计独立数据元素的数量。
3.好友关系:
集合可以用于表示用户之间的好友关系。通过将好友的ID存储在集合中,可以轻松地进行好友列表、共同好友和好友推荐等操作。
  •         sadd: 将好友的ID添加到集合中。
  •         srem: 从集合中删除指定的好友ID。
  •         sismember: 检查指定的用户是否为好友。
  •         smembers: 获取当前用户的所有好友。
4.权限管理:
集合可以用于实现权限管理系统。例如,可以将用户的权限名称存储在一个集合中,然后使用sismember命令来检查用户是否具有特定权限。
  •                 sadd: 将权限名称添加到集合中。
  •                 srem: 从集合中删除指定的权限名称。
  •                 sismember: 检查用户是否具有指定的权限。
5.兴趣匹配:
通过将用户的兴趣爱好存储在集合中,可以通过交集运算来找到具有共同兴趣的用户或进行兴趣匹配。
  •         sadd: 将用户的兴趣爱好添加到集合中。
  •         sinter: 计算两个或多个集合的交集,找到具有共同兴趣的用户。
6.订阅者系统:
集合可以用于存储和管理订阅者信息。例如,将订阅集合中的用户与发布集合中的发布者进行匹配,以实现消息发布和订阅模式。
  •         sadd: 将订阅者的信息添加到集合中。
  •         srem: 从集合中删除指定的订阅者。
  •         smembers: 获取所有订阅者的信息。

以上仅是一些在开发中使用Redis集合的示例,实际上,Redis的集合数据类型非常灵活和多功能,适用于许多实际场景。通过适当地使用集合命令和数据结构,可以构建高效、灵活和可扩展的应用程序

这篇关于向爬虫而生---Redis 基石篇4 <拓展Set>的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/565291

相关文章

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

poj 3050 dfs + set的妙用

题意: 给一个5x5的矩阵,求由多少个由连续6个元素组成的不一样的字符的个数。 解析: dfs + set去重搞定。 代码: #include <iostream>#include <cstdio>#include <set>#include <cstdlib>#include <algorithm>#include <cstring>#include <cm

Python3 BeautifulSoup爬虫 POJ自动提交

POJ 提交代码采用Base64加密方式 import http.cookiejarimport loggingimport urllib.parseimport urllib.requestimport base64from bs4 import BeautifulSoupfrom submitcode import SubmitCodeclass SubmitPoj():de

Collection List Set Map的区别和联系

Collection List Set Map的区别和联系 这些都代表了Java中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。 有序否 允许元素重复否 Collection 否 是 List 是 是 Set AbstractSet 否

论文翻译:ICLR-2024 PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS

PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS https://openreview.net/forum?id=KS8mIvetg2 验证测试集污染在黑盒语言模型中 文章目录 验证测试集污染在黑盒语言模型中摘要1 引言 摘要 大型语言模型是在大量互联网数据上训练的,这引发了人们的担忧和猜测,即它们可能已

Redis中使用布隆过滤器解决缓存穿透问题

一、缓存穿透(失效)问题 缓存穿透是指查询一个一定不存在的数据,由于缓存中没有命中,会去数据库中查询,而数据库中也没有该数据,并且每次查询都不会命中缓存,从而每次请求都直接打到了数据库上,这会给数据库带来巨大压力。 二、布隆过滤器原理 布隆过滤器(Bloom Filter)是一种空间效率很高的随机数据结构,它利用多个不同的哈希函数将一个元素映射到一个位数组中的多个位置,并将这些位置的值置

多路转接之select(fd_set介绍,参数详细介绍),实现非阻塞式网络通信

目录 多路转接之select 引入 介绍 fd_set 函数原型 nfds readfds / writefds / exceptfds readfds  总结  fd_set操作接口  timeout timevalue 结构体 传入值 返回值 代码 注意点 -- 调用函数 select的参数填充  获取新连接 注意点 -- 通信时的调用函数 添加新fd到

Python:豆瓣电影商业数据分析-爬取全数据【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】

**爬取豆瓣电影信息,分析近年电影行业的发展情况** 本文是完整的数据分析展现,代码有完整版,包含豆瓣电影爬取的具体方式【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】   最近MBA在学习《商业数据分析》,大实训作业给了数据要进行数据分析,所以先拿豆瓣电影练练手,网络上爬取豆瓣电影TOP250较多,但对于豆瓣电影全数据的爬取教程很少,所以我自己做一版。 目

Lua 脚本在 Redis 中执行时的原子性以及与redis的事务的区别

在 Redis 中,Lua 脚本具有原子性是因为 Redis 保证在执行脚本时,脚本中的所有操作都会被当作一个不可分割的整体。具体来说,Redis 使用单线程的执行模型来处理命令,因此当 Lua 脚本在 Redis 中执行时,不会有其他命令打断脚本的执行过程。脚本中的所有操作都将连续执行,直到脚本执行完成后,Redis 才会继续处理其他客户端的请求。 Lua 脚本在 Redis 中原子性的原因