标签云(Tag Cloud)常见于各种博客站点中,标签有利于网站内容分类,还可以用于相关性内容推荐。近日笔者有空把个人的开源博客Django_blog添加了一个新功能--标签云。最终效果请访问:http://foofish.net/blog/tags

实现原理

标签云最终展现出来的效果其实是由两个HTML参数来控制的,分别是:font-size和color,如:

django

标签关联的文章越多,表示这个标签被引用的次数越大,font-size的值也越大,color的颜色越深。考虑到体验效果,font-size不能随着的标签的引用次数的增大而无限增大,否则页面显得非常丑陋。因此会把font-size控制在某个区间,同理color也是在一个区间中。

这里我把font-size设置在12到33之间数组FONT_SIZES,标签的font-size属性只能是里面的一个值,COLORS是与FONT_SIZES对应的一个数组,12对应#ccc,15对应#adadad,以此类推。

MIN_FONT_SIZE = 12 # 最小尺寸

MAX_FONT_SIZE = 33 # 最大尺寸

FONT_SIZES = [MIN_FONT_SIZE, 15, 18, 21, 24, 27, 30, MAX_FONT_SIZE]

COLORS = ['#ccc', "#adadad", '#8e8e8e', '#6f6f6f', '#4f4f4f', '#303030', '#111', '#000']

现在关键问题就是如何根据标签的引用次数(tag_ref_count)来确定它的font-size。一旦font-size了,color也随之确定。要想标签的font-size能够均匀分布在数组FONT_SIZES中,那么要遵循的一个原则就是,随着次数的增加其font-size的取值也增加,而且引用次数最少的标签使用MIN_FONT_SIZE,引用次数最多的标签使用MAX_FONT_SIZE。

因此有一个公式,MIN_FONT_SIZE + n*step = MAX_FONT_SIZE,step是步长,n是指引用次数最多的标签减去引用次数最少的标签,表示两者之间总共有多少步step,根据此根式可以算出每一步的step值是多少,知道了步长后,就可以计算出任意一个标签的font-size了,任何一个标签到最小标签的步数是两者之差,因此每一个标签的font-size为 MIN_FONT_SIZE + (tag_ref_count-min_ref_count)*step

源代码:

# encoding: utf-8

__author__ = 'liuzhijun'

class TagCloud(object):

MIN_FONT_SIZE = 12

MAX_FONT_SIZE = 33

FONT_SIZES = [MIN_FONT_SIZE, 15, 18, 21, 24, 27, 30, MAX_FONT_SIZE]

COLORS = ['#ccc', "#adadad", '#8e8e8e', '#6f6f6f', '#4f4f4f', '#303030', '#111', '#000']

def __init__(self, min_ref_count, max_ref_count):

TagCloud.min_ref_count = min_ref_count

# 如果最大标签和最小标签相等,那么认为两者的步长为0,所有标签取同样的font-size.

if max_ref_count == min_ref_count:

TagCloud.step = 0

else:

TagCloud.step = (TagCloud.MAX_FONT_SIZE - TagCloud.MIN_FONT_SIZE) / (max_ref_count - min_ref_count)

def get_tag_font_size(self, tag_ref_count):

font_size = TagCloud.MIN_FONT_SIZE + (tag_ref_count - TagCloud.min_ref_count) * TagCloud.step

# 上面计算出来的font_size并不一定刚好是FONT_SIZES中的某个元素, 可以能某两个元素之间的某个值

# 因此要取最接近FONT_SIZES中某个元素

font_size = min(TagCloud.FONT_SIZES, key=lambda x: abs(font_size - x))

return font_size

def get_tag_color(self, tag_ref_count):

return TagCloud.COLORS[(TagCloud.FONT_SIZES.index(self.get_tag_font_size(tag_ref_count)))]

输出结果:

12,12,12,18,24,18,21,27,33,

有问题可以扫描二维码和我交流

关注公众号「Python之禅」,回复「1024」免费获取Python资源

python 标签云_标签云算法Python实现相关推荐

  1. 数据结构python课后答案_数据结构与算法:Python语言描述 1~5章课后习题

    数据结构与算法:Python语言描述 1~5章课后习题 发布时间:2018-07-19 20:42, 浏览次数:1885 , 标签: Python MarkDown语法写的,不知道为啥上传到CSDN不 ...

  2. 漫画算法python版下载_漫画排序算法Python实现

    冒泡排序 冒泡排序的思想,我们要把相邻的元素两两比较,当一个元素大于右侧相邻元素时, 交换它们的位置;当一个元素小于或等于右侧相邻元素时,位置不变. def bubbleSort(list): ran ...

  3. mooc数据结构与算法python版期末测验_中国大学MOOC(慕课)_数据结构与算法Python版_测试题及答案...

    中国大学MOOC(慕课)_数据结构与算法Python版_测试题及答案 更多相关问题 采用fopen()函数打开文件,支持文件读取的参数有: [简答题]简单阐述高分子材料热-机械特征及成型加工的关系,并 ...

  4. python编程基础_月隐学python第2课

    python编程基础_月隐学python第2课 学习目标 掌握变量的输入和输出 掌握数据类型的基本概念 掌握算数运算 1.变量的输入和输出 1.1 变量输入 使用input输入 input用于输入数据 ...

  5. 查看Python的版本_查看当前安装Python的版本

    一.查看Python的版本_查看当前安装Python的版本 具体方法: 首先按[win+r]组合键打开运行: 然后输入cmd,点击[确定]: 最后执行[python --version]命令即可. 特 ...

  6. python 免费空间_免费云空间/VPS AppFog申请及Python Web应用开发与上传实战

    欢迎转载,但请勿用于商业用途. 联系方式:jmppok@gmail.com 目前网络上有很多提供云存储.云空间.VPS的厂商,从功能.稳定性.易用性.人气等方面考虑,作者认为AppFog是一个不错的选 ...

  7. python seo百度_为SEO学习Python课程(python与seo百度云免费)

    SEO可能希望学习编程语言的原因有很多.本指南处理"如何"而不是"为什么".如果您已经到达这里,想知道Python(或编程)是否适合您-很好的起点是Britne ...

  8. python网课阿里云_阿里云大牛用过的680集Python视频教程无偿分享,学完万物皆可爬...

    Python已经成为一种再主流不过的编程语言了.它天生丽质,易于读写,非常实用,从而赢得广泛的群众基础,被誉为"宇宙最好的编程语言",被无数程序员热烈追捧. 随着时代的发展越来越快 ...

  9. 多元线性回归算法python实现_手写算法-Python代码推广多元线性回归

    1.梯度下降-矩阵形式 上篇文章介绍了一元线性回归,包括Python实现和sklearn实现的实例.对比,以及一些问题点,详情可以看这里: 链接: 手写算法-Python代码实现一元线性回归 里面封装 ...

最新文章

  1. 自然语言处理NLP基本知识小结
  2. 高级会计师资格考试成绩合格证在全国范围内几年有效
  3. 国际青年日,神策数据召唤优(有)质(志)青年
  4. 一个很简单的淡入淡出相册 (转)
  5. [转]wince中解析reg和bib文件的不同之处
  6. 苹果mac投屏软件:AirServer
  7. html5钟表带齿轮项目,基于HTML5的齿轮动画特效
  8. 40-42-网络层ARP协议,ARP欺骗,网络执法官和arp防火墙
  9. 【小程序】rpx(responsive pixel)自适应像素浅析
  10. DMA copy和CPU copy
  11. 虚拟服务器忘记密码,Win7系统下VMware虚拟机忘记开机密码如何解决
  12. bgfx入门练习2——找出DX,OpenGL驱动切换实现原理
  13. 上海地铁三号线(轻轨明珠线)各车站换乘和时刻表
  14. Git 六 时光穿梭机
  15. 实用主义学python【笔记】
  16. python 二进制流长度_python怎么处理二进制流
  17. nginx常用配置笔记
  18. HBase简介及安装
  19. SPH算法的理论和实践(2)
  20. Scrapy 爬取百度贴吧指定帖子的发帖人和回帖人

热门文章

  1. wxWidgets:wxWindowCreateEvent类用法
  2. boost::mp11::mp_clear相关用法的测试程序
  3. boost::function_types::result_type用法的测试程序
  4. boost::bad_function_call用法的测试程序
  5. GDCM:gdcm::Trace的测试程序
  6. boost::container实现devector选项程序
  7. ITK:矢量图像上的邻域迭代器
  8. DCMTK:DcmAttributeFilter类的测试程序
  9. VTK:PolyData之ShrinkPolyData
  10. VTK:Points之ExtractEnclosedPoints