百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

手把手教你做一个python+matplotlib的炫酷的数据可视化动图

ztj100 2025-02-04 17:11 15 浏览 0 评论

1.数据可视化动图,是数据可视化的高级显示,最近很流行。



2.比如下面将告诉你如何制作一个如下的数据可视化动图。


3.例:

3.1 准备一组数据,虚拟的csv资料,对应关系如下

4个项目:namegroupyearvalue

name:李明、张三、王二、许仙、汤博、陈皮、袁飞

group: ['安徽', '浙江', '江西', '上海','深圳', '北京', '重庆']

year:1968~2019

value:自己对应随便估计


3.2 我是先现在excel上编辑,然后另存为4.csv(注意一定是另存为,否则在导入数据时会出现格式不对)


3.3 python3.8+matplotlib作图前准备


3.4 代码修改注意:中文字体的设置,数据的导入,和代码的局部修改。


3.5 效果图

图1



3.6 本例虚拟数据的完整代码

图2



图3



图4



4.完整代码

#第1步:导出模块,固定
import pandas as pd
import matplotlib.pyplot as plt
import matplotlib.ticker as ticker 
import matplotlib.animation as animation

#第2步:中文字体显示设置1,导出通用字体设置,可调整
from matplotlib import font_manager 
#中文字体显示设置2,引出字体模块和位置
#注意此处字体size大小不设置就是默认,设置或不设置后会发现所有文字或汉字大小都固定在my_font,下面单独设size无效了
my_font = font_manager.FontProperties(fname="/usr/share/fonts/truetype/noto/simsun.ttf",size=14)
#中文字体显示设置,第3步,增加u和fontproperties=my_font,加不加u或r均可以

#第3步:导入数据,可调整,文件名和目录可调整
#将数据下载下来放在指定默认的目录和文件夹下
df = pd.read_csv('4.csv', 
                 usecols=['name', 'group', 'year', 'value'])
#定义全局变量
current_year = 2018

#第4步:定义dff和图片大小设置,可固定
dff=() #定义元组
fig, ax = plt.subplots(figsize=(15, 8))

#第5步:定义7组数据的颜色,group可调整,但颜色值可调整或者不调整
colors = dict(zip(
    ['安徽', '浙江', '江西', '上海','深圳', '北京', '重庆'],
    ['#adb0ff', '#ffb3ff', '#90d595', '#e48381','#aafbff', '#f7bb5f', '#eafb50']))

#第6步:从数据中取值,可固定
group_lk = df.set_index('name')['group'].to_dict()

#第7步:画图关键设置,可固定
def draw_barchart(year):
    dff = df[df['year'].eq(year)].sort_values(by='value', ascending=True).tail(10)
    ax.clear() #每次清空、刷新
    ax.barh(dff['name'], dff['value'], color=[colors[group_lk[x]] for x in dff['name']])
    dx = dff['value'].max() / 200
    
    for i, (value, name) in enumerate(zip(dff['value'], dff['name'])):
        #在text里加fontproperties=my_font,注意有my_font的地方size存在的意义不大,目前bug
        ax.text(value-dx, i,     name,           size=20,fontproperties=my_font, 
        weight=600, ha='right', va='bottom')
        ax.text(value-dx, i-.25, group_lk[name], size=10, fontproperties=my_font,
        color='#444444', ha='right', va='baseline')
        ax.text(value+dx, i,     f'{value:,.0f}',  size=14, ha='left',  va='center')
    #显示文字,x=0,y=1.10,坐标,ha=水平对准=水平线平放
    #ax.text()格式=(x,y,string,fontsize=15,verticalalignment="top",horizontalalignment="right")
    #string=字符串='文字内容'

    #汉字内容可调整,其他不动
    ax.text(0, 1.10, '1968 ~ 2018年我国各部分省和地区GDP变化',
            transform=ax.transAxes, size=18, fontproperties=my_font, 
            weight=600, ha='left') #文字标题,第1层
    ax.text(0, 1.04, 'GDP (万亿)', transform=ax.transAxes, size=12, 
    fontproperties=my_font, color='#777777') #显示文字,第2层
    ax.text(1, 0.4, year, transform=ax.transAxes, color='#777777', size=46, 
    ha='right', weight=800) #右边固定显示动图年份
    #va=verticalalignment="top",垂直对准
	#ha=horizontalalignment="right",alignment=对准,水平对准
    ax.xaxis.set_ticks_position('top')  #x轴在上面

    ax.set_yticks([]) #默认是显示y轴的名称,左边垂直的城市名字,设为[]就是不显示
    ax.margins(0, 0.01) #不设置就是默认值,缩放比例(0,0.05)
    ax.grid(which='major', axis='x', linestyle='--') #垂直线,布局和格式
    ax.set_axisbelow(True)  #默认是true的
    #默认是True,False之后不显示黑色线框
    plt.box(False) 
#以animator形式展现动画
animator = animation.FuncAnimation(fig, draw_barchart, frames=range(1968, 2019)) 

plt.show() #以plt的形式展现图片

5.完整代码,可搜索本人易三一世的其他博客

喜欢的可以点赞、加关注、评论和转发。

相关推荐

Vue3非兼容变更——函数式组件(vue 兼容)

在Vue2.X中,函数式组件有两个主要应用场景:作为性能优化,因为它们的初始化速度比有状态组件快得多;返回多个根节点。然而在Vue3.X中,有状态组件的性能已经提高到可以忽略不计的程度。此外,有状态组...

利用vue.js进行组件化开发,一学就会(一)

组件原理/组成组件(Component)扩展HTML元素,封装可重用的代码,核心目标是为了可重用性高,减少重复性的开发。组件预先定义好行为的ViewModel类。代码按照template\styl...

Vue3 新趋势:10 个最强 X 操作!(vue.3)

Vue3为前端开发带来了诸多革新,它不仅提升了性能,还提供了...

总结 Vue3 组件管理 12 种高级写法,灵活使用才能提高效率

SFC单文件组件顾名思义,就是一个.vue文件只写一个组件...

前端流行框架Vue3教程:17. _组件数据传递

_组件数据传递我们之前讲解过了组件之间的数据传递,...

前端流行框架Vue3教程:14. 组件传递Props效验

组件传递Props效验Vue组件可以更细致地声明对传入的props的校验要求...

前端流行框架Vue3教程:25. 组件保持存活

25.组件保持存活当使用...

5 个被低估的 Vue3 实战技巧,让你的项目性能提升 300%?

前端圈最近都在卷性能优化和工程化,你还在用老一套的Vue3开发方法?作为摸爬滚打多年的老前端,今天就把私藏的几个Vue3实战技巧分享出来,帮你在开发效率、代码质量和项目性能上实现弯道超车!一、...

绝望!Vue3 组件频繁崩溃?7 个硬核技巧让性能暴涨 400%!

前端的兄弟姐妹们五一假期快乐,谁还没在Vue3项目上栽过跟头?满心欢喜写好的组件,一到实际场景就频频崩溃,页面加载慢得像蜗牛,操作卡顿到让人想砸电脑。用户疯狂吐槽,领导脸色难看,自己改代码改到怀疑...

前端流行框架Vue3教程:15. 组件事件

组件事件在组件的模板表达式中,可以直接使用...

Vue3,看这篇就够了(vue3 从入门到实战)

一、前言最近很多技术网站,讨论的最多的无非就是Vue3了,大多数都是CompositionAPI和基于Proxy的原理分析。但是今天想着跟大家聊聊,Vue3对于一个低代码平台的前端更深层次意味着什么...

前端流行框架Vue3教程:24.动态组件

24.动态组件有些场景会需要在两个组件间来回切换,比如Tab界面...

前端流行框架Vue3教程:12. 组件的注册方式

组件的注册方式一个Vue组件在使用前需要先被“注册”,这样Vue才能在渲染模板时找到其对应的实现。组件注册有两种方式:全局注册和局部注册...

焦虑!Vue3 组件频繁假死?6 个奇招让页面流畅度狂飙 500%!

前端圈的朋友们,谁还没在Vue3项目上踩过性能的坑?满心期待开发出的组件,一到高并发场景就频繁假死,用户反馈页面点不动,产品经理追着问进度,自己调试到心态炸裂!别以为这是个例,不少人在电商大促、数...

前端流行框架Vue3教程:26. 异步组件

根据上节课的代码,我们在切换到B组件的时候,发现并没有网络请求:异步组件:...

取消回复欢迎 发表评论: