Redis 实现排行榜

不再介绍数据库做实时排行榜的弊端,直接介绍Redis的有序集合的强大作用。
有序集合的数据和集合一样,不能重复,但每个元素又可以关联一个分数,这个分数可以重复。
需要注意的是,redis版本和命令变化较大,注意运行环境。
运行环境:
redis 库版本:3.3.11
redis版本:3.2.1

1、从MongoDB中导入数据到Redis

生成数据:

import pymongo
import random

handler = pymongo.MongoClient('mongodb://127.0.0.1:27017').chapter_9.rank_data

for i in range(10000, 10100):
    data = {'user_id': i,
            'score': round(random.random() * 1000, 1)}
    handler.insert_one(data)

导入到有序集合中:

import pymongo
import redis


handler = pymongo.MongoClient('mongodb://127.0.0.1:27017').chapter_9.rank_data
client = redis.Redis()

rows = handler.find({}, {'_id': 0})
for row in rows:
    client.zadd("rank",{row['user_id']:row['score']})

zadd的第二个参数应该是字典。
查看导入的数据:
在这里插入图片描述

2、显示特定排名

import redis

client = redis.Redis()

count = client.zcard('rank')
print(f'当前共有{count}人')
position = client.zrevrank('rank', 10086)+1
print(f'用户‘10086’的排名为{position}')

在这里插入图片描述

3、显示全部排名

import redis

client = redis.Redis()

rank = client.zrevrangebyscore("rank", 100000, 0, withscores=True)
for index,one in enumerate(rank):
    print(f'排名:{index+1}, 用户ID:{one[0].decode()}, 积分:{one[1]}')

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值