当前位置: 首页 > 编程日记 > 正文

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

作者 | 叶庭云

来源 | 修炼Python

头图 | 下载于视觉中国

什么是 TIOBE 排行榜

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

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

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

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


获取数据

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

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

爬虫代码如下:

 1# -*- coding: UTF-8 -*-2"""3@Author  :叶庭云4@公众号  :修炼Python5@CSDN    :https://yetingyun.blog.csdn.net/6"""7import requests8import re9import openpyxl
10import logging
11
12logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s: %(message)s')
13headers = {
14    "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.1 (KHTML, like Gecko) Chrome/21.0.1180.89 Safari/537.1"
15}
16
17wb = openpyxl.Workbook()    # 创建工作簿对象
18sheet = wb.active           # 获取活动的工作表
19# 编程语言   时间    热度
20sheet.append(['Programing', 'Date', 'data_per'])
21
22url = 'https://www.tiobe.com/tiobe-index/'
23rep = requests.get(url, headers=headers).text
24
25# 正则匹配提取数据
26data = re.findall('{name : (.*?),data : (.*?)}', rep)
27programing = [eval(k[0]) for k in data]     # 编程语言
28dates = [i[1] for i in data]
29
30# 正则表达式处理 提取出想要的数据
31for x in range(len(dates)):
32    name = programing[x]
33    datas = re.findall(r'\[Date.UTC(.*?)]', dates[x], re.DOTALL)
34    for m in datas:
35        date1 = re.findall(r'\d+', m)       # 正则提取出数字
36        date2 = '-'.join(date1[:3])         # 拼接得到时间
37        data_per = '.'.join(date1[-2:])     # 得到热度数据
38        sheet.append([name, date2, data_per])
39        logging.info([name, date2, data_per])
40
41wb.save('language_data.xlsx')

结果如下:

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

1import pandas as pd
2
3df = pd.read_excel('language_data.xlsx')
4df.sample(10)
1df['Programing'].unique()3   df.info()


数据可视化

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

 1# -*- coding: UTF-8 -*-2"""3@Author  :叶庭云4@公众号  :修炼Python5@CSDN    :https://yetingyun.blog.csdn.net/6"""7import pandas as pd8import xlrd9import pyecharts.options as opts
10from pyecharts.charts import Timeline, Bar
11from pyecharts.globals import CurrentConfig, ThemeType
12
13
14CurrentConfig.ONLINE_HOST = 'D:/python/pyecharts-assets-master/assets/'
15
16# 提取现在的Top10编程语言
17name = list(pd.read_excel('language_data.xlsx')['Programing'].unique())
18
19data = xlrd.open_workbook('language_data.xlsx')
20table = data.sheets()[0]
21
22dic1 = {k: [] for k in name}
23# 各编程语言对应每年里不同时间的热度
24for i in range(1, table.nrows):
25 x = table.row_values(i)
26 dic1[x[0]].append((x[1], x[2]))
27
28# 与编程语言顺序对应  每年编程语言对应的不同时间的热度
29data_per = {k: [[] for x in range(10)] for k in range(2001, 2022)}
30print(data_per)
31
32count = 0
33for k, v in dic1.items():
34 print(k, v)
35for j in v:   # v (时间,热度)  热度数据添加进各年对应的列表里
36  data_per[int(j[0][:4])][count].append(eval(j[1]))  # 一年里各编程语言不同时间时的热度  对应
37 count += 1
38
39# print(data_per)
40data_per1 = {k: [] for k in list(data_per.keys())}
41
42for k, v in list(data_per.items()):
43for x in v:
44if len(x) == 0:                  # 这一年里该语言没有热度数据
45   data_per1[k].append(0)
46else:
47   avg = sum(x) / len(x)
48   data_per1[k].append(round(avg, 2))     # 这一年里的平均热度
49
50# 得到TOBIE现在排Top10的编程语言从2001年开始每年的平均热度
51print(data_per1)
52
53
54def get_year_overlap_chart(year) -> Bar:
55 sum_info = [(m, n) for m, n in zip(name, data_per1[year])]
56# 编程语言按每年平均热度排序
57 sum_info.sort(key=lambda z: z[1])
58 name_ = [m[0] for m in sum_info]
59 datas = [m[1] for m in sum_info]
60# 每根柱子的颜色列表
61 colors = ['#00BFFF', '#0000CD', '#000000', '#008000', '#FF1493', '#FFD700', '#FF4500', '#00FA9A', '#191970',
62'#9932CC']
63 data_1 = []
64for item in range(10):
65  data_1.append(
66   opts.BarItem(
67    name=name_[item],
68    value=datas[item],
69    itemstyle_opts=opts.ItemStyleOpts(color=colors[item])   # 设置每根柱子的颜色
70   )
71  )
72# 绘制柱形图
73 bar = Bar()
74 bar.add_xaxis(name_)
75 bar.add_yaxis(series_name='热度', yaxis_data=data_1, is_selected=True,
76                  label_opts=opts.LabelOpts(is_show=False))
77 bar.reversal_axis()
78 bar.set_global_opts(title_opts=opts.TitleOpts(
79      title="2011-2020年编程语言热度变化"),
80      tooltip_opts=opts.TooltipOpts(
81      is_show=True, trigger="axis", axis_pointer_type="shadow"),
82                  xaxis_opts=opts.AxisOpts(name='平均热度'), yaxis_opts=opts.AxisOpts(name='编程语言'),
83 )
84return bar
85
86
87# 生成时间轴的图
88timeline = Timeline(init_opts=opts.InitOpts(theme=ThemeType.MACARONS, width="1200px", height="600px"))
89for y in range(2011, 2021):
90 timeline.add(get_year_overlap_chart(y), time_point=str(y))
91
92timeline.add_schema(is_auto_play=True, play_interval=1000)
93timeline.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 的快捷方式。

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

更多精彩推荐
☞明年,我要用 AI 给全村写对联☞Ant Design 遭删库!☞每年节省170万美元的文档预览费用,借助机器学习的DropBox有多强?☞对比四种爬虫定位元素方法,你更爱哪个?点分享点收藏点点赞点在看

相关文章:

小扎的野心不止做社交 市政厅的上线说明了这一点

一个月前,扎克伯格刚在一封6千字长信里宣布了自己要做一个全球社区的理想,日前Facebook就上线了个叫“市政厅”的政务服务功能。 美国的用户在“市政厅”的功能页填写完自己的地理位置信息之后,可以看到当地政府官员的名单,包括美…

C#调用存储过程简单完整例子

CREATE PROC P_TEST Name VARCHAR(20), Rowcount INT OUTPUT AS BEGINSELECT * FROM T_Customer WHERE NAMENameSET RowcountROWCOUNT END GO ---------------------------------------------------------------------------------------- --存储过程调用如下: -------------…

高手的习惯:pythonic风格代码

来源 | Python大数据分析责编 | 寇雪芹头图 | 下载于视觉中国什么是pythonicpythonic是开发者们在写python代码过程中总结的编程习惯,崇尚优雅、明确、简单。就好比中文的笔画,讲究先后顺序,最符合文字书写的习惯。因为是习惯,不是…

计算机天才Aaron Swartz 名作 《如何提高效率》——纪念真正的“hacker!

如何提高效率 《HOWTO: Be more productive》(如何提高效率)作者:Aaron Swartz 肯定有人跟你说过这样的话,“你有看电视的那么长时间,都可以用来写一本书了”。不可否认写书肯定比看电视更好的利用了时间,但…

python的web压力测试工具-pylot安装使用

pylot是python编写的一款web压力测试工具。使用比较简单。而且测试结果相对稳定。 这里不得不鄙视一下apache 的ab测试,那结果真是让人蛋疼,同样的url,测试结果飘忽不定,看得人心惊肉跳,摸不着头脑。 下载 pylot官网&a…

快过HugeCTR:用OneFlow轻松实现大型推荐系统引擎

Wide & Deep Learning Wide & Deep Learning (以下简称 WDL)是解决点击率预估(CTR Prediction)问题比较重要的模型。WDL 在训练时,也面临着点击率预估领域存在的两个挑战:巨大的词表(Em…

路由的有类和无类

有类和无类路由1.通告时不以主类子网掩码通告,一条路由被通告出去的时候并没有自动汇总,而是以本身的子网掩码通告。即为无类路由。2.被通告的路由化成主类网络后和通告该路由的接口被化成主类网络后相比不是同一个网络,那么这台路由器就产生…

VS2005 常用快捷键

ShiftAltEnter: 切换全屏编辑CtrlB,T / CtrlK,K: 切换书签开关CtrlB,N / CtrlK,N: 移动到下一书签 CtrlB,P: 移动到上一书签 CtrlB,C: 清除全部标签CtrlI: 渐进式搜索 CtrlShiftI: 反向渐进式搜索CtrlF: 查找 CtrlShiftF: 在文件中查找F3: 查找下一个ShiftF3: 查找上一个CtrlH:…

2016政策与市场协同发力大数据,小公司如何搏杀BAT?

大数据这个词来到2016年,绽放出绚烂的光。 先看看最近几天的新闻:大数据分析腐败问题、大数据曝光基友的世界、大数据助交警查处多起毒驾……不仅仅是与经济相关,大数据正在渗透社会各个领域,与传统社会嫁接的大数据,正…

机器学习的第一个难点,是数据探索性分析

作者 | 陆春晖责编 | 寇雪芹头图 | 下载于视觉中国当我们在进行机器学习领域的学习和研究时,遇到的第一个难点就是数据探索性分析(Exploratory Data Analysis)。虽然从各种文献中不难了解到数据探索性分析的重要性和一般的步骤流程&#xff0…

Asp.net 1.0 升级至 ASP.NET 2.0十个问题总结

1.Global.asax文件的处理形式不一样 转化后将出现错误,在vs2003中Global.asax具有代码后置文件,2.0下, 将代码分离文件移到 App_Code 目录下,以便使其自动变为可通过应用程序中的任意 ASP.NET 页面访问。“Code-behind”属性将从 …

Robotium初探秘

2019独角兽企业重金招聘Python工程师标准>>> Getting started 如果想知道robotium是如何运行、什么样子的,就看下面的步骤。如果想自己新建一个robotium测试工程,点击 此处 要使用Robotium,需要把Robotium.jar放在测试工程的build…

初级Java程序员所面临的4大挑战

一、编码时间过长 作为入门级Java工程师,每周至少编程45小时,而且每个月会有1到2个星期工作50至60小时。从这些数字上看,过去几个月里每周工作将近50小时。80% –90%的工作时间都耗在了电脑前。这样的数字虽然表明了享…

javascript页面跳转常用代码

这东东最难记&#xff0c;每次需要时都是重新到Google上搜&#xff0c;真是烦死了&#xff0c;这回整理一下贴到这。 按钮式&#xff1a; <INPUT name"pclog" type"button" value"GO" onClick"location.hrefhttp://9ba.cn/"> 链…

frame,iframe,frameset之间的关系与区别

2019独角兽企业重金招聘Python工程师标准>>> ■ 框架概念 &#xff1a; 所谓框架便是网页画面分成几个框窗&#xff0c;同时取得多个 URL。只需要 <FRAMESET> <FRAME> 即可&#xff0c;而所有框架标记需要放在一个总起的 html 档&#xff0c;这个档案只…

最低售价17999元,华为发布新一代折叠屏手机Mate X2,将首批升级HarmonyOS

2019年&#xff0c;华为发布第一代折叠屏Mate X&#xff0c;开启了5G折叠屏手机新纪元&#xff1b;2020年&#xff0c;华为发布第二代折叠屏Mate Xs&#xff0c;实现了折叠屏手机从硬件到生态的演进。 2月22日&#xff0c;华为举行新一代折叠旗舰发布会&#xff0c;发布全新折…

「要拼就拼运维」5分钟一台?它让我爱上工作了!

高效运维轻松管理本文转自d1net&#xff08;转载&#xff09;

JavaScript去除字符串首尾空格

function trim(str) { return str.replace(//s/g,""); } javascript去除字符串空格的函数 function jtrim(s) { var i,b0,es.length; for(i0;i<s.length;i) //去左空格 if(s.charAt(i)! ){bi;break;} if(is…

server-send event object

http://jamie-wang.iteye.com/blog/1849193 event -- onmessage, onopen, onerror 不是方法&#xff0c;而是事件 http://school.youth.cn/px/lamp/2012/1130/38537.shtml http://www.ibm.com/developerworks/cn/web/1307_chengfu_serversentevent/index.html?cadrs http://bb…

拿来就能用!Dijkstra 算法实现快递路径优化

作者 | 李秋键责编 | 伍杏玲出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;近几年来&#xff0c;快递行业发展迅猛&#xff0c;其中的程序设计涉及到运送路径的最优选择问题&#xff0c;下面我们尝试模拟实现快递路径优化问题&#xff0c;假设为快递公司设计快递投递…

92号油的发动机能加97吗?标号越高不代表就越好

当我们买了车&#xff08;不管是二手还是新车吧&#xff09;&#xff0c;我们都能很快知道这车的发动机是加什么标号的汽油的。这些信息都能在说明书或者在加油盖附近找到。但同时很多粉丝也在问&#xff0c;我的车是92的&#xff0c;但我加97的话发动机会不会更有力更省油&…

不要跳槽!!!

在这个俗称“金三银四”的跳槽季&#xff0c;很多人都蠢蠢欲动&#xff0c;想要拿更高的薪资&#xff0c;想要去更大的平台......但我也要奉劝大家一句&#xff1a;三思而后行。确实&#xff0c;春节过后&#xff0c;大家都在为开年做准备&#xff0c;跳槽也好&#xff0c;学习…

按下回车键指向下一个位置的一个函数

functiontofocus(itemname) // 按回车置下一个位置 2{ 3vara 4aeval( " document.vouch. "itemname) 5a.focus() 6} 7 在控件中使用onkeypress" javascrip:if(window.event.keyCode13){tofocus(nextformname)}提取下一个控件名

初涉LR,关联

摘要&#xff1a;Loadrunner是一种很好的性能测试工具&#xff0c;它通过对创建Vuser脚本、定义场景、运行场景、分析结果四大模块来进行性能负载测试。 在回放脚本时有时会出现运行不成功的情况&#xff0c;有可能是因为之前所录制的参数与现实的不一致的原因&#xff0c;比如…

新型智能电视攻击,9成国外设备或受影响

在近日举办的欧洲广播联盟媒体网络安全研讨会上&#xff0c;瑞士安全研究员Rafael Scheel分享了一种针对智能电视的新型攻击方法&#xff1a;通过发送恶意数字视频地面广播信号(DVB-T)&#xff0c;实现远程控制电视设备并获得智能电视root访问权限&#xff0c;之后利用电视可以…

按esc键退出的一个函数

1functionesckey(keycode) // 按esc键退出2{ 3if (keycode 27 ) 4{ 5window.close() 6} 7}

Linux挂载卸载光盘实践

在Linux下有时候需要挂载光盘&#xff0c;拷贝文件或安装系统&#xff0c;例如拷贝Redhat操作系统镜像文件等。下面介绍一下在Linux系统下挂载、卸载光盘的方法。 在Linux系统中&#xff0c;每一个物理设备都可以看做是一个文件&#xff0c;而像硬盘、光盘等物理设备文件都在/d…

程序员晒元宵节福利,网友:看了我想砸键盘......

再过几天就到元宵节了&#xff0c;又到了互联网大厂晒福利、拉仇恨的时候了。小编在脉脉上看到许多不愿透露姓名的网友的爆料&#xff0c;一起来看看吧。有的网友说收到了汤圆&#xff0c;还有员工说收到了四盒草莓&#xff0c;但是还有网友透露自己喜提加班&#xff0c;更有甚…

tomcat_deploy 平滑启动脚本

1.此脚本需要nginx安装ginx_upstream_check_module 配置完成平滑重启 2.脚本内容如下&#xff1a; 1 #!/bin/bash2 cat <<MADAY3 ---------------------------------------------------------4 -------------------------------------------------------------5 A)服…

判断输入是否为中文的函数

1functionischinese(s){ 2varrettrue ; 3for ( vari0 ;i < s.length;i) 4 retret &&(s.charCodeAt(i) > 10000 ); 5returnret; 6 }