背景介绍

排行榜业务使用的频率实在太高了,各种活动都会使用排行榜。经过多次开发后我觉得实现一个简单的排行榜库,它能够完成当前我遇到的所有业务逻辑问题,也希望能够帮助到想要快速开发排行榜业务的同行。

我设计了landport游戏框架,但是目前该框架只是提供websocket的连接管理提供有些房间之间的通信等。还未投入生产而组件类的开发业余时间进行。例如接下来介绍的排行榜就可以投入使用了,期待更您的参与。github

安装

pip install landport

分析需要

产品说暑假就要到了,准备对我们的游戏做活动。那么如果玩家在这段时间内得分靠前就可以获得礼品,礼品是按照不同的排名分不同的等级。

我们需要解决的第一问题是怎么排序,然后是怎么匹配奖品。假设我们的数据格式如下:

data = [
{
"uid" : 10011,
"score": 120,
},
{
"uid": 10022,
"score":230
},
{
"uid": 10033,
"score":222
},
{
"uid": 10044,
"score":30
} ]

这是我们的初始化数据,一般这些数据是通过数据库获取到的。下面声明一个排行榜实例,排行榜有一个需求是显示用户的榜单是上升还是下降,这个需要数据库缓存上一次的结果,目前使用的缓存是redis数据库实现。所以这里需要大家安装并且启动你的redis数据库。

import redis
from landport.core.rank import RanklistBase as Ranklist
r = redis.Redis("127.0.0.1", 6379, 0)
rk = Ranklist('my_redis_cache', r)

下面是把我们的数据一个个push_in到我们的排行榜中,这里我们使用一个循环去加载数据。

for item in data:
rk.push_in(item)

我们的排行榜有了数据后就可以进行相应的操作了,首先是排序。

rk.sort_by("score")

我们排序完成后可以通过下面的方式得到排序后的排行榜。

new_data = rk.top(10)

下面查看当前的全部代码如下:

import redis
from landport.core.rank import RanklistBase as Ranklist r = redis.Redis("127.0.0.1", 6379, 0) data = [
{
"uid" : 10011,
"score": 120,
},
{
"uid": 10022,
"score":230
},
{
"uid": 10033,
"score":222
},
{
"uid": 10044,
"score":30
} ] if __name__ == '__main__':
print(data)
rk = Ranklist('my_redis_cache', r)
for item in data:
rk.push_in(item)
rk.sort_by("score")
new_data = rk.top(10)
print(new_data)

目前我们只是得到了一个按照给定的项逆序排好了,我们并没有给出这是第几名。当然我们知道下标是0的是第一名,客户端的人就不一定这样认为了。我们可以继续改进如下:

rk.sort_by("score").add_rank(care='score')



这时候看起来工作才不多收尾了,让产品过来看看。

产品说他们想给用户更加强烈的竞争感,所以希望排行榜有上升的箭头或者落后的箭头。

我当时思考了半天,现在你不需要思考了。直接使用下面的方式即可。

rk.sort_by("score").add_rank(care='score').add_trend()

下面给出两次调用的运行截图。

我想解释一下trend项,我设计的时候定义了如下规则

-1 ---> 名次下降
0 ---> 名次不变
1 ---> 名次上升

当要与客户端联调的时候发现,自己忘记加奖品了。不过使用landport你可以调用add_gift实现奖品的添加,只需要配置好奖品的映射就可以了。下面咱们先设计好奖品的配置。

gift_config = {
"1":{
"name":"iPhone 7 plus",
"something":"something"
},
"2~3":{
"name":"Nokia ...",
"something":"gift img url"
},
"4":{
"name":"flower",
"something":"desc ."
}
}

然后继续链式调用我们的add_gift方法。

rk.sort_by("score").add_rank(care='score').add_trend().add_gift(gift_config)

总结

目前为止我们实现了一个简单的排行榜示例,还有很多功能我没有演示。例如:同名的情况证明出来,查看我自己的排名怎么处理。等等有些功能库已经实现,有些则我会慢慢增加库的开发,也期待你的参与。最后给出所有代码

import redis
from landport.core.rank import RanklistBase as Ranklist r = redis.Redis("127.0.0.1", 6379, 0) data = [
{
"uid" : 10011,
"score": 120,
},
{
"uid": 10022,
"score":230
},
{
"uid": 10033,
"score":222
},
{
"uid": 10044,
"score":30
} ] gift_config = {
"1":{
"name":"iPhone 7 plus",
"something":"something"
},
"2~3":{
"name":"Nokia ...",
"something":"gift img url"
},
"4":{
"name":"flower",
"something":"desc ."
}
} if __name__ == '__main__':
print(data)
rk = Ranklist('my_redis_cache', r)
for item in data:
rk.push_in(item)
rk.sort_by("score").add_rank(care='score').add_trend().add_gift(gift_config)
new_data = rk.top(10)
print(new_data)

使用python landport库快速实现排行榜的更多相关文章

  1. Python第三方库wordcloud(词云)快速入门与进阶

    前言: 笔主开发环境:Python3+Windows 推荐初学者使用Anaconda来搭建Python环境,这样很方便而且能提高学习速度与效率. 简介: wordcloud是Python中的一个小巧的 ...

  2. Python标准库14 数据库 (sqlite3)

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python自带一个轻量级的关系型数据库SQLite.这一数据库使用SQL语言.S ...

  3. 常用python机器学习库总结

    开始学习Python,之后渐渐成为我学习工作中的第一辅助脚本语言,虽然开发语言是Java,但平时的很多文本数据处理任务都交给了Python.这些年来,接触和使用了很多Python工具包,特别是在文本处 ...

  4. [Python] 机器学习库资料汇总

    声明:以下内容转载自平行宇宙. Python在科学计算领域,有两个重要的扩展模块:Numpy和Scipy.其中Numpy是一个用python实现的科学计算包.包括: 一个强大的N维数组对象Array: ...

  5. python常用库

    本文由 伯乐在线 - 艾凌风 翻译,Namco 校稿.未经许可,禁止转载!英文出处:vinta.欢迎加入翻译组. Awesome Python ,这又是一个 Awesome XXX 系列的资源整理,由 ...

  6. python标准库00 学习准备

    Python标准库----走马观花 python有一套很有用的标准库.标准库会随着python解释器一起安装在你的电脑上的.它是python的一个组成部分.这些标准库是python为你准备的利器,可以 ...

  7. Python图像处理库:Pillow 初级教程

    Python图像处理库:Pillow 初级教程 2014-09-14 翻译 http://pillow.readthedocs.org/en/latest/handbook/tutorial.html ...

  8. Python标准库的学习准备

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python标准库是Python强大的动力所在,我们已经在前文中有所介绍.由于标准 ...

  9. Python标准库——走马观花

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python有一套很有用的标准库(standard library).标准库会随着 ...

随机推荐

  1. 数组的map方法

    map方法 不支持IE6.7 .8 array1.map(fn) array1.map(fn[,thisArg]) 注意: fn 必须是函数,如果不是函数则会报错  TypeError: undefi ...

  2. 源码(07) -- java.util.Iterator<E>

    java.util.Iterator<E> 源码分析(JDK1.7) ----------------------------------------------------------- ...

  3. Exiting the Matrix: Introducing Metasploit's Hardware Bridge

    Metasploit is an amazing tool. You can use it to maneuver through vast networks, pivoting through se ...

  4. C++编程练习(11)----“图的最短路径问题“(Dijkstra算法、Floyd算法)

    1.Dijkstra算法 求一个顶点到其它所有顶点的最短路径,是一种按路径长度递增的次序产生最短路径的算法. 算法思想: 按路径长度递增次序产生算法: 把顶点集合V分成两组: (1)S:已求出的顶点的 ...

  5. 基于canvas的二维码邀请函生成插件

    去年是最忙碌的一年,实在没时间写博客了,看着互联网行业中一个又一个人的倒下,奉劝大家,健康要放在首位,保重身体.好了,言归正传,这是17年的第一篇博文,话说这天又是产品同学跑过来问我说:hi,lenn ...

  6. Java虚拟机中Java内存区域

      Java虚拟机所管理的内存将会包括以下几个运行时数据区域. 程序计数器 可以看作是当前线程所执行的字节码的行号指示器. 每一个线程都需要有一个独立的程序计数器. 如果线程正在执行的是一个Java方 ...

  7. Padding Borders Outlines Margins

    简介: 在20世纪90年代,许多网页布局是使用table,使用table最主要的原因是因为可以放text到一个盒子里,但是这是一个比较复杂的过程,现在可以使用比较简单的方法,那就是css. 元素盒子: ...

  8. [bzoj1067][SCOI2007]降雨量——线段树+乱搞

    题目大意 传送门 题解 我国古代有一句俗话. 骗分出奇迹,乱搞最神奇! 这句话在这道题上得到了鲜明的体现. 我的方法就是魔改版线段树,乱搞搞一下,首先借鉴了黄学长的建树方法,直接用一个节点维护年份的区 ...

  9. Finding distance between two curves

    http://answers.opencv.org/question/129819/finding-distance-between-two-curves/ 问题: Hello, Im trying ...

  10. Dijkstra算法的二叉堆优化

    Dijkstra算法的二叉堆优化 算法原理 每次扩展一个距离最小的点,再更新与其相邻的点的距离. 如何寻找距离最小的点 普通的Dijkstra算法的思路是直接For i: 1 to n 优化方案是建一 ...