安装pyecharts
# 在anaconda prompt命令行工具下,通过pip清华镜像源安装pyecharts
输入:pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pyecharts
# echarts官网:https://www.echartsjs.com/index.html
# pyecharts官网:https://pyecharts.org/#/zh-cn/intro
# pyecharts众多图表示例代码:https://gallery.pyecharts.org/#/README
# pyecharts github项目国内镜像: https://gitee.com/mirrors/pyecharts
绘制柱形图和折线图融合在同一个坐标系
数据示例:
年份(年) | 诊疗量(万人次) | 同比增速(%) |
---|---|---|
2014 | 87430 | 7.40 |
2015 | 90912 | 4.00 |
2016 | 96225 | 5.83 |
2017 | 101885 | 5.81 |
2018 | 107147 | 5.16 |
2019 | 116390 | 8.63 |
2020 | 105764 | -9.13 |
2021 | 120215 | 13.66 |
代码:
import pyecharts
from pyecharts import options as opts
from pyecharts.charts import Bar, Grid, Line
x_data = ['2014年','2015年','2016年','2017年','2018年','2019年','2020年','2021年'] #x轴标签
#配置柱形图
bar = (
Bar()
.add_xaxis(x_data) #导入x轴
.add_yaxis(
"诊疗量(万人次)", #柱形图图例名
[87430, 90912, 96225, 101885, 107147, 116390, 105764, 120215], #柱形图数据
yaxis_index=0, #表示y轴的索引,用于拥有多个y轴的单图表中。
color="#d14a61",
).set_series_opts(
itemstyle_opts=opts.ItemStyleOpts( #图元样式配置项
opacity=0.5), #设置柱形图透明度:0.5
)
.extend_axis(
yaxis=opts.AxisOpts(
name="诊疗量(万人次)", #柱形图y轴名称
type_="value",
position="left", #柱形图y轴在左边显示
axisline_opts=opts.AxisLineOpts(
linestyle_opts=opts.LineStyleOpts(color="#d14a61 ") #轴名称颜色
),
)
)
#设置全局配置项
.set_global_opts(
title_opts=opts.TitleOpts(title='2014-2021年中国中医类医疗卫生机构诊疗量'), #标题名称
legend_opts=opts.LegendOpts(pos_left='45%' ), #图例距离左边边距:40%
tooltip_opts=opts.TooltipOpts(trigger='axis', axis_pointer_type='cross'), #显示提示框组件
toolbox_opts=opts.ToolboxOpts(is_show=True) #显示工具栏
)
#折线图元素
.extend_axis(
yaxis=opts.AxisOpts(
type_="value",
name="同比增速(%)", #折线图y轴名称
position="right", #折线图y轴在右边显示
axisline_opts=opts.AxisLineOpts(linestyle_opts=opts.LineStyleOpts(color="#675bba"))#轴名称颜色
)
)
)
#配置折线图
line = (
Line()
.add_xaxis(x_data) #导入x轴
.add_yaxis(
"同比增速(%)", #折线图图例名称
[7.40,4.00,5.83,5.81,5.16,8.63,-9.13,13.66], #折线图数据
yaxis_index=2, #表示y轴的索引,用于拥有多个y轴的单图表中。
color="#675bba", #折线颜色
label_opts=opts.LabelOpts(is_show=False), #不显示柱形图数据
)
)
#最后整合
bar.overlap(line)
grid = Grid()
grid.add(bar, opts.GridOpts(pos_left="10%", pos_right="10%"), is_control_axis_index=True) #调整画布距离左边10%,距右边10%
grid.render_notebook() #渲染到nontebook中展示