大数跨境
0
0

用 pyecharts 制作数据可视化大屏之数据地图

用 pyecharts 制作数据可视化大屏之数据地图 俊红的数据分析之路
2021-01-16
1
导读:如题。
前段时间,给大家分享过 20 个炫酷的数据可视化大屏,源代码都是基于 echarts 的,于是我产生了用 Python 来实现数据可视化大屏的想法。

参考上面这个模板,我计划用 pyecharts 实现一个类似的数据可视化大屏。

今天先绘制中间的数据地图,为了方便演示,我们采用一个超市数据集,数据来源于 Tableau 官方示例。

如果你还没有安装 pyecharts,那么请先打开命令行,运行以下代码:

# 安装或更新 v1 以上版本,目前是 1.9.0pip3 install pyecharts -U

在 Jupyter Lab 中新建一个 Notebook,运行以下代码:

# 声明 Notebook 类型,必须在引入 pyecharts.charts 等模块前声明from pyecharts.globals import CurrentConfig, NotebookTypeCurrentConfig.NOTEBOOK_TYPE = NotebookType.JUPYTER_LAB
# 导入相关库from pyecharts import options as optsfrom pyecharts.charts import Mapfrom pyecharts.globals import ThemeType import pandas as pd
# 从 data 文件夹读取 Excel 中的数据df = pd.read_excel('./data/超市数据.xlsx')
# 用数据透视表的方法汇总各省销售额province_sale = df.pivot_table(values='销售额', index='省/自治区', aggfunc=sum)
# 把数据整理成绘图所需的列表格式,规范名称,销售额换算成万元,保留一位小数list_province_sale = [list(z) for z in zip(province_sale.index.str.replace('自治区', ''), round(province_sale.销售额/10000, 1))]
# 求各省销售额的最大值max_sale = round(province_sale.销售额.max()/10000,0)
# 标题,数字千分位格式显示title = "{:,}".format(int(province_sale.销售额.sum()))
# 副标题subtitle = '\t\t2016年到2019年总销售额'
# 绘制地图c = ( # 主题样式和背景颜色 Map(init_opts=opts.InitOpts(theme=ThemeType.SHINE, chart_id=1, bg_color='#00589F')) # 添加地图数据 .add("", list_province_sale, "china") # 全局配置 .set_global_opts( # 标题文字 title_opts=opts.TitleOpts(title=title, # 副标题 subtitle=subtitle, # 标题位置 pos_left='39%', pos_top=20, # 标题颜色和大小 title_textstyle_opts=opts.TextStyleOpts(color="#FBC171", font_size=36), # 副标题颜色和大小 subtitle_textstyle_opts=opts.TextStyleOpts(color="#CCCCCC", font_size=15)), # 可视化组件参数 visualmap_opts=opts.VisualMapOpts( # 最大值 max_=max_sale, # 显示精确的分段值 is_piecewise=True, # 图例位置 pos_left='30%', pos_bottom=10, # 图例字体颜色 textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"))) # 隐藏文字标签 .set_series_opts(label_opts=opts.LabelOpts(is_show=False)))
# 在 Jupyter Lab 中第一次渲染时需要调用_ = c.load_javascript()

然后,运行以下代码:

# 需要与 load_javascript 在不同的单元格中运行c.render_notebook()

就能得到如下数据地图:

对于颜色的深浅和气泡的大小,我们的感知能力其实是比较弱的,通常很难精准地判断差异。

从有效传递信息的角度来看,我认为上面这种分段式的数据地图,比普通的热力地图和气泡地图更加有效。

喜欢文章的话,点个“在看”哦

【声明】内容源于网络
0
0
俊红的数据分析之路
《对比Excel》系列图书作者、出版有Python数据分析、SQL数据分析、Python报表自动化多本畅销书,主要分享数据分析工具、数据分析理论、数据分析思维、数据分析实战相关内容。
内容 909
粉丝 0
俊红的数据分析之路 《对比Excel》系列图书作者、出版有Python数据分析、SQL数据分析、Python报表自动化多本畅销书,主要分享数据分析工具、数据分析理论、数据分析思维、数据分析实战相关内容。
总阅读46
粉丝0
内容909