Python使用Redis实现排行榜介绍(python redis操作)
off999 2024-11-04 13:17 27 浏览 0 评论
软件开发过程中经常遇到产品的排行榜需求。例文章浏览量排行榜、文章点赞排行榜、图书销量Top50排行榜、粉丝Top100排行榜、用户积分排行榜等。排行榜前期可以使用的产品用户激励,后期可以使用在产品内容推荐、数据统计、广告营销方面。
排行榜一般对数据实效性要求很高。太低的数据实效性可能达不到对用户的激励作用。今天为大家介绍我们借助Redis的高并发高性能和Redis的zset有序集合特性实现排行榜的高负载和高实时性。
1、Python Redis安装
#mac redis安装
brew install redis
#python redis安装
pip install redis
#python redis官方文档
https://redis.readthedocs.io/en/latest/commands.html#core-commands
2、Redis ZADD增加成员(移除冗余数据)
import redis
"""
@author 312每天一个短知识
@desc Redis排行榜类
@date 2022-04-28 23:48:12
"""
class RedisRank:
"""
排行榜最大记录数
"""
MAX_COUNT = 3
"""
@author 312每天一个短知识
@desc 初始化构造函数
@date 2022-04-28 23:48:12
"""
def __init__(self):
self._conn = redis.StrictRedis(host='127.0.0.1', port=6379, db=0)
"""
@author 312每天一个短知识
@desc 新增一条记录
@date 2022-04-28 23:48:12
"""
def zadd(self, key, member, score):
res = self._conn.zadd(key, {member: score})
total = self._conn.zcard(key)
#set集合中数据超过阈值移动阈值外的成员保证Redis内存使用量和服务稳定性
if self.MAX_COUNT < total:
self._conn.zremrangebyrank(key, 0, total - self.MAX_COUNT - 1)
return res
"""
@author 312每天一个短知识
@desc 移除集合里冗余的数据
@date 2022-04-28 23:48:12
"""
def zremrangebyrank(self, key, start, stop):
return self._conn.zremrangebyrank(key, start, stop)
"""
@author 312每天一个短知识
@desc 求集合记录总数
@date 2022-04-28 23:48:12
"""
def zcard(self, key):
return self._conn.zcard(key)
3、Redis ZINCRBY增量成员score
import redis
"""
@author 312每天一个短知识
@desc Redis排行榜类
@date 2022-04-28 23:48:12
"""
class RedisRank:
"""
排行榜最大记录数
"""
MAX_COUNT = 3
"""
@author 312每天一个短知识
@desc 初始化构造函数
@date 2022-04-28 23:48:12
"""
def __init__(self):
self._conn = redis.StrictRedis(host='127.0.0.1', port=6379, db=0)
"""
@author 312每天一个短知识
@desc 增量集合成员score值
@date 2022-04-28 23:48:12
"""
def zincrby(self, key, member, score):
return self._conn.zincrby(key, score, member)
4、Redis ZREVRANGE从高到低score排序
import redis
"""
@author 312每天一个短知识
@desc Redis排行榜类
@date 2022-04-28 23:48:12
"""
class RedisRank:
"""
排行榜最大记录数
"""
MAX_COUNT = 3
"""
@author 312每天一个短知识
@desc 初始化构造函数
@date 2022-04-28 23:48:12
"""
def __init__(self):
self._conn = redis.StrictRedis(host='127.0.0.1', port=6379, db=0)
"""
@author 312每天一个短知识
@desc 从高到低排行set数据
@date 2022-04-28 23:48:12
"""
def zrevrange(self, key, min, max):
return self._conn.zrevrange(key, min, max, withscores=True)
5、Python Redis业务代码
#导入模块并实例化类
from rank import RedisRank
rrank = RedisRank()
#测试set rank数据
rrank.zadd("t2", 'a1', 10)
rrank.zadd("t2", 'a2', 8)
rrank.zadd("t2", 'a3', 15)
rrank.zadd("t2", 'a4', 12)
rrank.zadd("t2", 'a5', 20)
rrank.zadd("t2", 'a6', 11)
rrank.zadd("t2", 'a7', 17)
rrank.zadd("t2", 'a8', 19)
#增量set成员score
rrank.zincrby("t2", 'a8', 5.0)
#set集合排行榜
setrank = rrank.zrevrange("t2", 0, -1)
for member, score in setrank:
print(member, score)
执行结果:
b'a8' 24.0
b'a5' 20.0
b'a7' 17.0
6、总结
- 业务代码在ZADD时考虑排行的数据量一般都很大,所以增加了set集合总数超过阈值移除阈值外的集合成员的逻辑。一方面节约Redis内存使用量,另一方面提升服务稳定性(排行榜的数据不与业务数据量的增加而增长)。
- zadd时间复杂度O(k*log(n))k为添加成员个数。n为当前成员个数。zrevrange时间复杂度O(log(n)+k)k为要获取的成员个数,n为当前成员个数。从Redis命令时间复杂度看增加阈值限制set集合的成员个数对时间复杂度很有价值。
大家如果有更好的排行榜处理方式可以评论沟通。
感谢大家的评论、点赞、分享、关注。。。
相关推荐
- PYTHON-简易计算器的元素介绍
-
[烟花]了解模板代码的组成importPySimpleGUIassg#1)导入库layout=[[],[],[]]#2)定义布局,确定行数window=sg.Window(...
- 如何使用Python编写一个简单的计算器程序
-
Python是一种简单易学的编程语言,非常适合初学者入门。本文将教您如何使用Python编写一个简单易用的计算器程序,帮助您快速进行基本的数学运算。无需任何高深的数学知识,只需跟随本文的步骤,即可轻松...
- 用Python打造一个简洁美观的桌面计算器
-
最近在学习PythonGUI编程,顺手用Tkinter实现了一个简易桌面计算器,功能虽然不复杂,但非常适合新手练手。如果你正在学习Python,不妨一起来看看这个项目吧!项目背景Tkint...
- 用Python制作一个带图形界面的计算器
-
大家好,今天我要带大家使用Python制作一个具有图形界面的计算器应用程序。这个项目不仅可以帮助你巩固Python编程基础,还可以让你初步体验图形化编程的乐趣。我们将使用Python的tkinter库...
- 用python怎么做最简单的桌面计算器
-
有网友问,用python怎么做一个最简单的桌面计算器。如果只强调简单,在本机运行,不考虑安全性和容错等的话,你能想到的最简单的方案是什么呢?我觉得用tkinter加eval就够简单的。现在开整。首先创...
- 说好的《Think Python 2e》更新呢!
-
编程派微信号:codingpy本周三脱更了,不过发现好多朋友在那天去访问《ThinkPython2e》的在线版,感觉有点对不住呢(实在是没抽出时间来更新)。不过还好本周六的更新可以实现,要不就放一...
- 构建AI系统(三):使用Python设置您的第一个MCP服务器
-
是时候动手实践了!在这一部分中,我们将设置开发环境并创建我们的第一个MCP服务器。如果您从未编写过代码,也不用担心-我们将一步一步来。我们要构建什么还记得第1部分中Maria的咖啡馆吗?我们正在创...
- 函数还是类?90%程序员都踩过的Python认知误区
-
那个深夜,你在调试代码,一行行检查变量类型。突然,一个TypeError错误蹦出来,你盯着那句"strobjectisnotcallable",咖啡杯在桌上留下了一圈深色...
- 《Think Python 2e》中译版更新啦!
-
【回复“python”,送你十本电子书】又到了周三,一周快过去一半了。小编按计划更新《ThinkPython2e》最新版中译。今天更新的是第五章:条件和递归。具体内容请点击阅读原文查看。其他章节的...
- Python mysql批量更新数据(兼容动态数据库字段、表名)
-
一、应用场景上篇文章我们学会了在pymysql事务中批量插入数据的复用代码,既然有了批量插入,那批量更新和批量删除的操作也少不了。二、解决思路为了解决批量删除和批量更新的问题,提出如下思路:所有更新语...
- Python Pandas 库:解锁 combine、update 和compare函数的强大功能
-
在Python的数据处理领域,Pandas库提供了丰富且实用的函数,帮助我们高效地处理和分析数据。今天,咱们就来深入探索Pandas库中四个功能独特的函数:combine、combine_fi...
- 记录Python3.7.4更新到Python.3.7.8
-
Python官网Python安装包下载下载文件名称运行后选择升级选项等待安装安装完毕打开IDLE使用Python...
- Python千叶网原图爬虫:界面化升级实践
-
该工具以Python爬虫技术为核心,实现千叶网原图的精准抓取,突破缩略图限制,直达高清资源。新增图形化界面(GUI)后,操作门槛大幅降低:-界面集成URL输入、存储路径选择、线程设置等核心功能,...
- __future__模块:Python语言版本演进的桥梁
-
摘要Python作为一门持续演进的编程语言,在版本迭代过程中不可避免地引入了破坏性变更。__future__模块作为Python兼容性管理的核心机制,为开发者提供了在旧版本中体验新特性的能力。本文深入...
- Python 集合隐藏技能:add 与 update 的致命区别,90% 开发者都踩过坑
-
add函数的使用场景及错误注意添加单一元素:正确示例:pythons={1,2}s.add(3)print(s)#{1,2,3}错误场景:试图添加可变对象(如列表)会报错(Pytho...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)