作者 | 叶庭云   责编 | 张文

前言

TIOBE 排行榜是根据互联网上有经验的程序员、课程和第三方厂商的数量,并使用搜索引擎(如Google、Bing、Yahoo!)以及Wikipedia、Amazon、YouTube 统计出排名数据,只是反映某个编程语言的热门程度,并不能说明一门编程语言好不好,或者一门语言所编写的代码数量多少。

TIOBE 开发语言排行榜每月更新一次,依据的指数是基于世界范围内的资深软件工程师和第三方供应商提供,其结果作为当前业内程序开发语言的流行使用程度的有效指标。

该指数可以用来检阅开发者的编程技能能否跟上趋势,或是否有必要作出战略改变,以及什么编程语言是应该及时掌握的。观察认为,该指数反应的虽并非当前最流行或应用最广的语言,但对世界范围内开发语言的走势仍具有重要参考意义。

2020 年,Python 再次获得年度编程语言荣誉。Python 在人工智能和数据科学领域的应用越来越来广泛,且在过去的一年里,Python 在处理疫情数据和舆情数据也发挥了巨大作用。至此,Python 已经第四次获得年度编程语言荣誉。

获取数据

获取 TIOBE 官网里历年编程语言热度数据,目标URL:https://www.tiobe.com/tiobe-index/

分析网页源代码可以找到我们想要的数据,利用正则表达式提取出数据,并保存到 Excel 中,便于后续数据处理和可视化。

爬虫代码如下:

# -*- coding: UTF-8 -*-"""@Author  :叶庭云@公众号  :修炼Python@CSDN    :https://yetingyun.blog.csdn.net/"""import requestsimport reimport openpyxlimport logging
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s: %(message)s')headers = {    "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.1 (KHTML, like Gecko) Chrome/21.0.1180.89 Safari/537.1"}
wb = openpyxl.Workbook()    # 创建工作簿对象sheet = wb.active           # 获取活动的工作表# 编程语言   时间    热度sheet.append(['Programing', 'Date', 'data_per'])
url = 'https://www.tiobe.com/tiobe-index/'rep = requests.get(url, headers=headers).text
# 正则匹配提取数据data = re.findall('{name : (.*?),data : (.*?)}', rep)programing = [eval(k[0]) for k in data]     # 编程语言dates = [i[1] for i in data]
# 正则表达式处理 提取出想要的数据for x in range(len(dates)):    name = programing[x]    datas = re.findall(r'\[Date.UTC(.*?)]', dates[x], re.DOTALL)    for m in datas:        date1 = re.findall(r'\d+', m)       # 正则提取出数字        date2 = '-'.join(date1[:3])         # 拼接得到时间        data_per = '.'.join(date1[-2:])     # 得到热度数据        sheet.append([name, date2, data_per])        logging.info([name, date2, data_per])
wb.save('language_data.xlsx')

结果如下:

成功提取出数据,并保存到Excel,在 jupyter notebook 环境中查看数据:

import pandas as pd
df = pd.read_excel('language_data.xlsx')df.sample(10)

df['Programing'].unique()
df.info()

数据可视化

利用 pyecharts 绘制时间轮播图数据可视化,展示现在热度排 Top10 的编程语言 2011-2020 年这十年里平均热度变化。

# -*- coding: UTF-8 -*-"""@Author  :叶庭云@公众号  :修炼Python@CSDN    :https://yetingyun.blog.csdn.net/"""import pandas as pdimport xlrdimport pyecharts.options as optsfrom pyecharts.charts import Timeline, Barfrom pyecharts.globals import CurrentConfig, ThemeTypeCurrentConfig.ONLINE_HOST = 'D:/python/pyecharts-assets-master/assets/'
# 提取现在的Top10编程语言name = list(pd.read_excel('language_data.xlsx')['Programing'].unique())
data = xlrd.open_workbook('language_data.xlsx')table = data.sheets()[0]
dic1 = {k: [] for k in name}# 各编程语言对应每年里不同时间的热度for i in range(1, table.nrows): x = table.row_values(i) dic1[x[0]].append((x[1], x[2]))
# 与编程语言顺序对应  每年编程语言对应的不同时间的热度data_per = {k: [[] for x in range(10)] for k in range(2001, 2022)}print(data_per)
count = 0for k, v in dic1.items(): print(k, v) for j in v:   # v (时间,热度)  热度数据添加进各年对应的列表里  data_per[int(j[0][:4])][count].append(eval(j[1]))  # 一年里各编程语言不同时间时的热度  对应 count += 1
# print(data_per)data_per1 = {k: [] for k in list(data_per.keys())}
for k, v in list(data_per.items()): for x in v:  if len(x) == 0:                  # 这一年里该语言没有热度数据   data_per1[k].append(0)  else:   avg = sum(x) / len(x)   data_per1[k].append(round(avg, 2))     # 这一年里的平均热度
# 得到TOBIE现在排Top10的编程语言从2001年开始每年的平均热度print(data_per1)def get_year_overlap_chart(year) -> Bar: sum_info = [(m, n) for m, n in zip(name, data_per1[year])] # 编程语言按每年平均热度排序 sum_info.sort(key=lambda z: z[1]) name_ = [m[0] for m in sum_info] datas = [m[1] for m in sum_info] # 每根柱子的颜色列表 colors = ['#00BFFF', '#0000CD', '#000000', '#008000', '#FF1493', '#FFD700', '#FF4500', '#00FA9A', '#191970',     '#9932CC'] data_1 = [] for item in range(10):  data_1.append(   opts.BarItem(    name=name_[item],    value=datas[item],    itemstyle_opts=opts.ItemStyleOpts(color=colors[item])   # 设置每根柱子的颜色   )  ) # 绘制柱形图 bar = Bar() bar.add_xaxis(name_) bar.add_yaxis(series_name='热度', yaxis_data=data_1, is_selected=True,                  label_opts=opts.LabelOpts(is_show=False)) bar.reversal_axis() bar.set_global_opts(title_opts=opts.TitleOpts(      title="2011-2020年编程语言热度变化"),      tooltip_opts=opts.TooltipOpts(      is_show=True, trigger="axis", axis_pointer_type="shadow"),                  xaxis_opts=opts.AxisOpts(name='平均热度'), yaxis_opts=opts.AxisOpts(name='编程语言'), ) return bar# 生成时间轴的图timeline = Timeline(init_opts=opts.InitOpts(theme=ThemeType.MACARONS, width="1200px", height="600px"))for y in range(2011, 2021): timeline.add(get_year_overlap_chart(y), time_point=str(y))
timeline.add_schema(is_auto_play=True, play_interval=1000)timeline.render("language_2011_2020.html")

结果如下:

解决有时候 pyecharts 绘制的图形渲染在网页上无法加载 js 文件的问题

  • 根据网站资源引用说明:pyecharts 使用的所有静态资源文件存放于 pyecharts-assets 项目中

  • 这个文件默认挂载在 https://assets.pyecharts.org/assets/,因为默认优先从远程引用资源,这就导致有的时候无法加载 js 文件,图表显示不出来。

解决办法:下载所需 js 文件到本地,修改资源引用地址,Github地址:https://github.com/pyecharts/pyecharts-assets看网站的介绍,pyecharts提供了更改全局 HOST 的快捷方式

from pyecharts.globals import CurrentConfig
CurrentConfig.ONLINE_HOST = 'D:/python/pyecharts-assets-master/assets/' # 本地保存 js 资源的路径

☞小米回应造车传闻;饿了么就春节“套路”骑手活动致歉;Go 1.16 正式发布 | 极客头条☞破圈!不止于浏览器,WebAssembly 2020 大事记☞X86 "将死"?RISC-V 正当立
☞C++落选,2021年最想学习的五大编程语言

一图看尽编程语言十年热度变化!相关推荐

  1. 一张图,看编程语言十年热度变化

    作者 | 叶庭云 来源 | 修炼Python 头图 | 下载于视觉中国 什么是 TIOBE 排行榜 TIOBE 排行榜是根据互联网上有经验的程序员.课程和第三方厂商的数量,并使用搜索引擎(如Googl ...

  2. 一张图看懂数据库十年大格局!

    [欢迎关注微信公众号:厦门微思网络] 数据库大佬们的十年兴衰 一张图看尽! ↓ 这个TOP10排名 包含了SQL和NoSQL 原始数据在这里 [数据库市场份额十年走势图] ↓ (小图看不清,点击看大图 ...

  3. c java python go 哪种编程语言接近编程的本质_一图看懂编程语言迁移模式:终点站是Python、Go、JS...

    新智元报道 来源:apenwarr 编辑:元子 [新智元导读]有着20年编程经验的资深程序员,以自己多年来的经历,总结出程序员的编程语言切换规律,做了一个主流编程语言的进阶流程图,展示不同编程语言之间 ...

  4. 一图看懂编程语言迁移模式:终点站是Python、Go、JS

    [新智元导读]有着20年编程经验的资深程序员,以自己多年来的经历,总结出程序员的编程语言切换规律,做了一个主流编程语言的进阶流程图,展示不同编程语言之间的承接关系.程序员选择编程语言的方向和路径. 铁 ...

  5. 一图看清公募基金十年持仓行业变迁

    图:权益类公募基金中信一级行业配置占比 来源:华安证券 截至2020年3季度末,公募偏股基金数量达到2800余只,持股市值达到了2.89万亿元. 同时,银行理财子公司陆续获批,保险资管.社保基金.FO ...

  6. 一图看尽全生态, 2018区块链产业云图重磅发布

    一图看尽全生态, 2018区块链产业云图重磅发布! 如果说2017是区块链元年,那么2018年就是区块链的应用之年.在一片「缺乏落地」的声音中,区块链应用无论在深度还是在广度上都迈上了一个新台阶. 在 ...

  7. 思维导图的三招十八式

    思维导图的三招十八式  张鄂勇 编著 ISBN978-7-121-14010-5 2012年1月出版 定价:49.00元 16开 396页 宣传语:会降龙十八掌,才混得到九袋弟子.         懂 ...

  8. 《思维导图的三招十八式》读书笔记

    1.书籍信息 --------------------------------------------------------- 书籍名称:思维导图的三招十八式 作者:张鄂勇 出版社:电子工业出版社 ...

  9. 思维导图的三招十八式之梳理

    说到思维导图的三招十八式,很多人都希望用它来学习思维导图,里面讲解了很多MindManager和MindMapper的使用方法和技巧,不过,撇除这些,思维导图的三招十八式这本书也是蛮厚实的,想要快速了 ...

最新文章

  1. js MediaSource h264
  2. 【vue-router①】router-link跳转页面传递参数 - 进击的前端之路(偶尔爬坑java小路) - SegmentFault 思否
  3. C语言字符篇(五)内存函数
  4. 2021年商业地产趋势洞察白皮书
  5. linux配置sftp-server,Ubuntu Server如何配置SFTP(建立用户监狱)
  6. Linux修改挂载目录名称
  7. python模块:网络协议和支持
  8. 酷比魔方iwork8刷机shell_酷比魔方iwork8超级版双系统刷机教程,remix+Windows10,序列号i1开头数字结尾...
  9. Android控件全解手册 - 玩转TextView属性
  10. 基于PyQt5与opencv制作的证件照尺寸变换应用程序
  11. Typora完整教程
  12. 国际信用卡VISA/MasterCard/AE/DC/JCB 卡号结构
  13. 最简单的搭建及使用本地服务器
  14. 单目标跟踪——个人笔记
  15. Google 黑板报: 哀悼与团结的曲线
  16. 2019北邮计算机机试
  17. 21条最佳实践,全面保障 GitHub 使用安全
  18. oracle begin exception end,Oracle Exception异常处理
  19. Chrome谷歌浏览器实现书签云同步,免费无会员
  20. 微信公众号H5页面实现扫一扫功能

热门文章

  1. CleanCodeHandbook Chapter 1: Array/String(1-16)
  2. spring boot 使用devtools热部署
  3. java——Random类和Math.Rondom
  4. Jmeter七、jmeter中的参数化
  5. Spring Boot 集成 Redis 实现缓存机制
  6. Kettle计算器的使用以及字符串格式化
  7. linux 下Eclipse for C/C++的不常见设置
  8. Android 代码动态生成ProgressBar
  9. Linux下让Eclipse支持Python
  10. 关于as400的基于关键字编译大揭秘