• redis实现排行榜功能


    redis的zset可以很方便地用来实现排行榜功能,下面简单介绍python如何使用redis实现排行榜功能

    加入排行榜

    获取redis实例

    import redis
    main_rds = redis.StrictRedis(host='localhost',port=6379,db=0,password='')
    

    全量加入排行榜

    注意根据redis包的版本不同,zadd和zincby的传参方式也不同

    对于redis 3.0(python的redis包)以下的版本

    # 向key为name的zset里面添加一个member,其分数为score,如果已经存在就覆盖
    main_rds.zadd(name,score,member)
    

    示例

    main_rds.zadd("test",100,"a")
    

    对于redis 3.0(python的redis包)及以上的版本
    # 向key为name的zset里面添加一个member,其分数为score,如果已经存在就覆盖
    main_rds.zadd(name,{member:score})
    

    示例

    main_rds.zadd("test",{"b":90,"c":80})	# 可以一次加入多个
    

    增量加入排行榜

    对于redis 3.0(python的redis包)以下的版本

    # # 向key为name的zset里面添加一个member,其分数为score,如果已经存在就增量添加
    main_rds.zincrby(name,member,amount)
    

    示例

    main_rds.zincrby("test","love",10)		# 10.0,一次只能加入一个
    main_rds.zincrby("test","love",-1)		# 9.0
    

    对于redis 3.0(python的redis包)及以上的版本
    # 向key为name的zset里面添加一个member,其增量分数为score,如果不存在就添加
    main_rds.zincrby(name,amount,member)
    

    示例

    main_rds.zincrby("test",8,"beauty")		# 8.0
    main_rds.zincrby("test",-2,"beauty")		# 6.0
    

    操作排行榜

    获取某个member的排名

    # 获取某个member的排名,按score从小到大排名,从0开始
    main_rds.zrank(name,member)
    # 获取某个member的排名,按score从大到小排名,从0开始
    main_rds.zrevrank(name,meber)
    

    示例

    main_rds.zadd("test",{"a":1,"b":2,"c":3})
    main_rds.zrank("test","a")	# 0
    main_rds.zrevrank("test","a")	# 2
    

    获取某个meber的score

    main_rds.zscore(key,member)
    

    示例

    main_rds.zscore("test","c")		# 3.0
    

    获取排名在某个区间的元素

    # 返回key为name的zset(按score从大到小排序)中的index从start到end(顾头也顾尾)的所有元素
    main.zrevrange(name, start, end, withscores=False)
    

    示例

    main_rds.zadd("test",{"d":5.1,"e":6,"f":7})		# 3
    # 顾头也顾尾
    main_rds.zrevrange("test",0,3)		# ['f', 'e', 'd', 'c']
    

    获取score在某个区间的元素

    # 返回key为name的zset中score(从小到大)在给定区间(顾头也顾尾)的元素
    main_rds.zrangebyscore(name, min, max, start=None, num=None, withscores=False)
    

    示例

    # 顾头也顾尾
    main_rds.zrangebyscore("test",2,6)		# ['b', 'c', 'd', 'e']
    

    获取score在给定区间的元素数量

    # 返回key为name的zset中score在给定区间的数量
    main_rds.zcount(name, min, max)
    

    示例

    main_rds.zcount("test",2,6)		# 4L
    

    获取整个zset的元素个数

    main_rds.zcard(name)
    

    示例

    main_rds.zcard("test")	# 6
    

    删除某个元素

    # 删除key为name里面的元素
    main_rds.zrem(name, *values)
    

    示例

    main_rds.zrevrange("test",0,10)			# ['love', 'f', 'beauty']
    main_rds.zrem("test","f")				# 1
    main_rds.zrem("test","love","beauty")	# 2		
    

    删除排名在某个区间的元素

    # 删除key为name的zset中排名在给定区间的元素
    main_rds.zremrangebyrank(name, min, max)
    

    示例

    main_rds.zremrangebyrank("test",0,2)	# 3
    

    #### 删除score在某个区间的元素
    # 删除key为name的zset中score在给定区间的元素
    main_rds.zremrangebyscore(name, min, max)
    

    示例

    main_rds.zremrangebyscore("test", 5, 6)		# 2
    
  • 相关阅读:
    IOException while loading persisted sessions:java.io.EOFException
    Android Studio | 详细安装教程
    Android -- 关闭AsyncTask(异步任务)
    钢铁侠传-文言文
    http协议 get/post 请求 解析XML
    HTTP状态码大全
    jquery+ajax 类百度输入框
    这就是知识点
    关于Eclipse+SVN 开发配置
    企业信息化快速开发平台--JeeSite
  • 原文地址:https://www.cnblogs.com/zzliu/p/11787830.html
Copyright © 2020-2023  润新知