版权声明:本文为博主原创文章,转载 请注明出处:https://blog.csdn.net/sc2079/article/details/83153693

- 写在前面


  好久没更新博客了,主要还是最近太忙了。很久之前就看到B站上动态柱状图图表(用D3.js做的),详情见@Jannchie见齐的主页。感觉很不错,于是便自己也做一哈。正好前一阵子写了脚本对中国大学MOOC的课程信息进行了爬取,经过修改后弄成了定时爬虫。经过近一个月爬取,数据已经挺多的啦,可以开始类似动态展示了。

  如果需要查阅爬虫脚本的,可参见我的博客:

  中国大学MOOC课程信息爬取与数据存储

- 环境配置




  运行环境:Python3.6、Spyder

  依赖的模块:pandas、mysql等

- 开始工作


1. 数据

  从9月20日至今,已有28张表格(以爬取日期命名),每张表格中都有一两千条课程数据,如下:

2. 开源动态可视化项目

  下载开源项目

  Historical-ranking-data-visualization-based-on-d3.js

  解压打开后,可以看到示例的example文件





  步骤很简单,只需根据示例文件格式添加数据即可。对于比较复杂的设置,如添加顶部附加信息或自定义颜色等,打开config,js和visual.js进行相应修改。

  打开压缩包内的bargraph.html网页并添加待可视化的表格文件即可。

3. 获取每天选课热度前10课程

'''获取热度每天选课热度前15课程'''
def get_top_hot(quire_condition):
db = pymysql.connect(host='localhost',user='root',passwd='root',db='mooc_courses_infos',charset='utf8') #连接数据库
cur = db.cursor()
sql = 'SHOW TABLES'
cur.execute(sql) #遍历所有表格
tables= cur.fetchall()
top_hot={} #热度
for table in tables:
data=table[0][9:11]+'-'+table[0][12:14] #日期标准化
cur.execute("select course,id,stu_num from %s"% table+" where start_time like '%s'"% quire_condition+" ORDER BY stu_num desc limit 10")
result=cur.fetchall()
top_hot[data]=result
return top_hot
'''热度top10课程写入CSV表格'''
def save_csv(subject,top_hot):
all_data=() #所有数据初始化
date=[] #日期
order=[] #每日热度排名
for data in top_hot:
_order=[i+1 for i in range(len(top_hot[data]))] #每日排名编号
order.extend(_order)
all_data+=top_hot[data] #添加数据
date.extend([data for _ in top_hot[data]]) #日期
dataframe = pd.DataFrame(list(all_data)) #数据字典化
dataframe.columns = ['name','type','value'] #修改标签
dataframe['type']=order #将type列值改为每日热度的排名
dataframe['date']=date #添加日期列
path='C:\\Users\\Administrator\\Desktop\\Historical-ranking-data-visualization-based-on-d3.js-master\\src\\'
'''将DataFrame存储为csv,index表示是否显示行名,default=True'''
dataframe.to_csv(path+subject+'.csv',index=False,sep=',') #写入csv

  需要说明的是因为课程进程不一致,为了相对公正一些,我这里将其分为三类:已结束的、正在进行的、即将开始的,分别获取每日热度top10。

conditions={'已结束':'已结束%','即将开始':'%开课%','正在进行':'进行至%'}  #查询条件集
condition='已结束' #查询条件
quire_condition=conditions[condition] #SQL语句中的查询条件
top_hot=get_top_hot(quire_condition) #获取指定查询条件下所有课程热度前10
save_csv(condition,top_hot) #存入SCV表格

4. 获取指定课程门类下每天选课热度前10课程

'''获取指定门类课程名称和ID'''
def get_kc_kind(subject):
subject_ids=[]
db = pymysql.connect(host='localhost',user='root',passwd='root',db='mooc_courses_info2',charset='utf8')
cur = db.cursor()
cur.execute("select id from %s"% subject) #获取表所有课程ID
results=cur.fetchall()
for result in results:
subject_ids.append(result[0])
return subject_ids
'''获取指定门类课程的选课人数变化'''
def get_hot_by_subject(subject_ids):
subject_ids=tuple(subject_ids)
db = pymysql.connect(host='localhost',user='root',passwd='root',db='mooc_courses_infos',charset='utf8')
cur = db.cursor()
sql = 'SHOW TABLES'
cur.execute(sql) #遍历指定数据库所有表
tables= cur.fetchall()
top_hot={} #热度
for table in tables: #特定日期
data=table[0][9:11]+'-'+table[0][12:14] #日期标准化
'''查询条件:在指定门类下ID范围内;正在进行的课程;课程热度由高到低前10'''
sql2 = "select course,id,stu_num from %s"% table+" where id in (%s)" % ','.join(['%d']*len(subject_ids)) % subject_ids \
+" and start_time like '进行至%' ORDER BY stu_num desc limit 10"
cur.execute(sql2)
result=cur.fetchall()
top_hot[data]=result
return top_hot

  这里值得说的是SQL查询语句where in下变量的表达,使用了format(花了不少功夫才得以解决)。

subjects={'国家精品':'excellent_course','计算机':'computer','经济管理':'management','心理学':'psychology',
'外语':'language','文学历史':'literary_history','艺术设计':'art','工学':'engineering',
'理学':'science','生命科学':'biomedicine','哲学':'philosophy','法学':'law',
'教育教学':'teaching_method'}
_subjects=list(subjects.keys()) #课程门类中文名列表
for subject in _subjects:
subject_Eng=subjects[subject] #课程门类英文名
subject_ids=get_kc_kind(subject_Eng) #获取该门类下所有ID
subject_top_hot=get_hot_by_subject(subject_ids) #该门类下每日课程热度前10
save_csv(subject,subject_top_hot) #写入CSV

- 结果展示


1. 正在进行的所有课程每日热度前10

2. 即将开课的所有课程每日热度前10

3. 已结束的所有课程每日热度前10

4. 计算机门类下正在进行课程每日热度前10

5. 国家精品门类下正在进行课程每日热度前10

- 写在最后


  运行程序时发现挺快的,只有几秒钟,因此代码优化暂时不着急做。在绘制动态图表时,为了展示效果更好还需要学习下开源项目的代码,进行相应优化提升。另图表中有些Bug,比如有些值显示不出来,为NaN。

  最后还是非常感谢大佬的开源奉献!

MOOC课程信息D3.js动态可视化的更多相关文章

  1. 中国大学MOOC课程信息爬取与数据存储

    版权声明:本文为博主原创文章,转载 请注明出处: https://blog.csdn.net/sc2079/article/details/82016583 10月18日更:MOOC课程信息D3.js ...

  2. 中国大学MOOC课程信息之数据分析可视化一

    版权声明:本文为博主原创文章,转载 请注明出处:https://blog.csdn.net/sc2079/article/details/82263391 9月2日更:中国大学MOOC课程信息之数据分 ...

  3. 中国大学MOOC课程信息之数据分析可视化二

    版权声明:本文为博主原创文章,转载 请注明出处:https://blog.csdn.net/sc2079/article/details/82318571 - 写在前面 本篇博客继续对中国大学MOOC ...

  4. [资料搜集狂]D3.js数据可视化开发库

    偶然看到一个强大的D3.js,存档之. D3.js 是近年来十分流行的一个数据可视化开发库. 采用BSD协议 源码:https://github.com/mbostock/d3 官网:http://d ...

  5. d3.js:数据可视化利器之快速入门

    hello,data! 在进入d3.js之前,我们先用一个小例子回顾一下将数据可视化的基本流程. 任务 用横向柱状图来直观显示以下数据: var data = [10,15,23,78,57,29,3 ...

  6. d3.js:数据可视化利器之 selection:选择集

    选择集/selection 选择集/selection是d3中的核心对象,用来封装一组从当前HTML文档中选中的元素: d3提供了两个方法用来创建selection对象: select(selecto ...

  7. d3.js:数据可视化利器之 交互行为:响应DOM事件

    selection.on:事件监听操作符 on()操作符可以添加或移除选择集中每个 DOM元素的事件监听函数: selection.on(type[,listener[,capture]]) 参数ty ...

  8. d3.js:数据可视化利器之 修改文档:DOM操作符

    style: CSS样式操作符 style()操作符用来设置或获取选择集中各DOM元素的CSS样式: selection.style(name[,value[,priority]]) style()操 ...

  9. 【 D3.js 进阶系列 — 6.1 】 缩放的应用(Zoom)

    缩放(Zoom)是另一种重要的可视化操作,主要是使用鼠标的滚轮进行. 1. zoom 的定义 缩放是由 d3.behavior.zoom() 定义的. var zoom = d3.behavior.z ...

随机推荐

  1. 网页布局(html+css基础)

    一.如何用CSS进行网页布局 二.网页布局基础 三.网页简单布局之结构和表现原则 四.CSS Sprite雪碧图应用 什么叫布局? 网页的特点: 网页自适应宽度: 网页长度无限延长: (分栏也叫分列, ...

  2. 【C/C++开发】ffplay中的FrameQueue的自我理解

    最近在研究ffplay,以下是本人今天在研究FrameQueue的时候整理的笔记,如有错误还请有心人指出来~ //这个队列是一个循环队列,windex是指其中的首元素,rindex是指其中的尾部元素. ...

  3. C#API解决自定义请求头下的跨域问题

    解决方法一: public class CrosHandler : DelegatingHandler { private const string Origin = "Origin&quo ...

  4. Xmemcached与SpringBoot实际案例

    在本人的这篇文章<Xmemcached集群与SpringBoot整合>基础上,进行XMemcached与SpringBoot实际案例的结合. 有以下这张表,将这张表的增删改查操作都添加到X ...

  5. cent8安装postgres

    postgres是一款免费.开源的对象型关系数据库,其在cent8的安装方式与cent7的不太一样,特此记录. 步骤: 1 安装postgres server dnf install postgres ...

  6. Vue.js与React的全面对比

    Vue与React的对比 Vue.js与React.js从某些反面来说很相似,通过两个框架的学习,有时候对一些用法会有一点思考,为加深学习的思索,特翻阅了两个文档,从以下各方面进行了对比,加深了对这两 ...

  7. [转帖]分享一份珍藏多年的PG数据库部署架构图

    分享一份珍藏多年的PG数据库部署架构图 记得同事曾经测试过citus https://www.toutiao.com/i6710613553277043213/ 原创 波波说运维 2019-07-11 ...

  8. Git强制推送代码到多个远程仓库

    git push -f origin master 注释: origin 远程仓库名, master 分支名,-f 为force,意为:强行.强制.

  9. shell习题第22题:

    [题目要求] 加入A服务器可直接ssh到B,不用输入密码.A和B都有一个目录是/data/web/这下有很多文件,我们不知道这下面有多少层目录,但是之前的目录结构和文件是一模一样的.但是现在不确定是否 ...

  10. (八)二进制文件在webservice中的处理(以byte[]字节数组方式)

    一.介绍 二进制文件在webservice中的处理. A:通过byte[]字节数组的方式来传递.比较适合小文件,字节数组不能太大的情况.(本章所用) B:通过DataHander的方式来进行传递. 1 ...