# 导入需要的库
from pyecharts.charts import Bar, Line
from pyecharts import options as opts
from pyecharts.globals import ThemeType
x_data = ["2014", "2015", "2016", "2017", "2018", "2019", "2020", "2021"]
bar = (
Bar(init_opts=opts.InitOpts(width="1000px", height="600px"))
.add_xaxis(xaxis_data=x_data)
.add_yaxis(
series_name="诊疗量(万人次)",
y_axis=[87430,90912,96225,101885,107147,116390,105764,120215,],
label_opts=opts.LabelOpts(is_show=False),
z_level = 0,
# 柱状图所有图形的 zlevel 值。
# z_level: types.Numeric = 0,
# 柱状图组件的所有图形的z值。控制图形的前后顺序。
# z值小的图形会被z值大的图形覆盖。
# z相比zlevel优先级更低,而且不会创建新的 Canvas。
)
.extend_axis( # 扩展 X/Y 轴
yaxis=opts.AxisOpts( # yaxis新增 Y 坐标轴配置项,AxisOpts坐标轴配置项
name="同比增速(%)",
type_="value", #'value': 数值轴,适用于连续数据
min_=-20,
max_=20,
interval=10, # 强制设置坐标轴分割间隔
axislabel_opts=opts.LabelOpts(formatter="{value} %"),# 坐标轴标签配置项 formatter回调函数,value传入的数据值
)
)
.set_global_opts(
# tooltip_opts=opts.TooltipOpts(# TooltipOpts:提示框配置项
# is_show=False, ),
xaxis_opts=opts.AxisOpts( # 坐标轴配置项
type_="category", #'category': 类目轴,适用于离散的类目数据,为该类型时必须通过 data 设置类目数据。
# axispointer_opts=opts.AxisPointerOpts(is_show=True, type_="shadow"), # 坐标轴指示器配置项
), # is_show是否显示坐标轴指示器,type_指示器类型# 'line' 直线指示器'shadow' 阴影指示器'none' 无指示器
yaxis_opts=opts.AxisOpts(
name="诊疗量(万人次)",
type_="value",
min_=0,
max_=130000,
interval=50000, # 强制设置坐标轴分割间隔
axislabel_opts=opts.LabelOpts(formatter="{value}"), # 坐标轴标签配置项
# axistick_opts=opts.AxisTickOpts(is_show=True), # 坐标轴刻度配置项
# splitline_opts=opts.SplitLineOpts(is_show=True), # 分割线配置项
),
)
)
bar.set_global_opts(
title_opts=opts.TitleOpts(title='2014-2021年中国中医类医疗卫生机构诊疗量',
pos_left='30%'), # 设置标题及位置
legend_opts=opts.LegendOpts(is_show=False)) # 设置不显示图例组件的配置项
line = (
Line()
.add_xaxis(xaxis_data=x_data)
.add_yaxis(
series_name="同比增速(%)",
yaxis_index=1, # 使用的 y 轴的 index,在单个图表实例中存在多个 y 轴的时候有用
y_axis=[7.40,4.00,5.83,5.81,5.16,8.63,-9.13,13.66],
symbol='triangle', symbol_size=20, # 设置折线图的图标样式及大小
label_opts=opts.LabelOpts(is_show=False), # 设置不显示图例
z_level = 2,
)
)
# bar.overlap(line).render("mixed_bar_and_line.html")
bar.overlap(line).render_notebook() # 渲染到notebook中展示
运行结果