使用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

需求:请用一张独立画布,分别绘制饼图和环图展示表4数据

Pie类表示饼图,add()方法可以为饼图添加数据和配置项

import numpy as np
import pyecharts.options as opts
from pyecharts.charts import Pie
#往该实例填充数据
data = [("化学药",33),("中成药",45),("生物制品",3),("保健品",9),("中药饮片",6),("其他",4)]
#通过导入的类创建实例
pie = Pie()
pie.add("",data)
pie.set_global_opts(title_opts=opts.TitleOpts(title="饼图示例"))
pie.render_notebook()#渲染到notebook上

展示的图表如下:

import numpy as np
import pyecharts.options as opts
from pyecharts.charts import Pie
data = [("化学药",33),("中成药",45),("生物制品",3),("保健品",9),("中药饮片",6),("其他",4)]
#通过导入的类创建实例
pie = Pie()
pie.add("",data,radius=["40%", "70%"])
pie.set_global_opts(title_opts=opts.TitleOpts(title="全国药店药品销售额占比",subtitle="用于展示中药市场趋势"),
                    toolbox_opts=opts.ToolboxOpts(is_show=True))
pie.render_notebook()#渲染到notebook上

展示图表:

 

 需求: 请用一张独立画布,柱形图和折线图融合在同一个坐标系展示表1数据

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轴的单图表中。
        z=2,
        color="pink",
    ).set_series_opts(
                     itemstyle_opts=opts.ItemStyleOpts(               #图元样式配置项
                     ),                                    
        )
    .extend_axis(
        yaxis=opts.AxisOpts(
            name="诊疗量(万人次)",      #柱形图y轴名称
            type_="value",
            position="left",               #柱形图y轴在左边显示
        )
    ).set_global_opts(                                             #设置全局配置项
        title_opts=opts.TitleOpts(title='2014-21年中医类医疗卫生机构诊疗量'),   #设置柱形图的标题名称
    )
    .extend_axis(
        yaxis=opts.AxisOpts(
            type_="value", 
            name="同比增速(%)",      #折线图y轴名称
            position="right",          #折线图y轴在右边显示
            )
        )
    )
 
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="yellow",   #折线颜色   
        label_opts=opts.LabelOpts(is_show=False),  #不显示柱形图数据
        z=3
    )
)
#overlap传入的必须为直角坐标系类型图表 ,柱形图层叠折线图
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中展示

展示图表如下:

from pyecharts.charts import Bar,Line
from pyecharts import options as opts

x_data = ['2014', '2015', '2016', '2017', '2018', '2019', '2020']
y_data_1 = [87430,90912,96225,101885,107147,116390,105764,120215]
y_data_2 = [7.40,4.00,5.83,5.81,5.16,8.63,-9.13,13.66]



def bar_line_combine_with_two_axis():
    bar = Bar(init_opts=opts.InitOpts(theme='light',
                                      width='1000px',
                                      height='600px'))
    bar.add_xaxis(x_data)
    # 添加一个Y轴
    bar.extend_axis(yaxis=opts.AxisOpts())
    bar.add_yaxis('诊疗量', y_data_1, yaxis_index=0)

    line = Line(init_opts=opts.InitOpts(theme='light',
                                        width='1000px',
                                        height='600px'))
    line.add_xaxis(x_data)
    # 将line数据通过yaxis_index指向后添加的Y轴
    line.add_yaxis('同比增长', y_data_2, yaxis_index=1)

    bar.overlap(line)
    return bar


chart = bar_line_combine_with_two_axis()
chart.render_notebook()

展示图表如下:

import pyecharts.options as opts   
from pyecharts.charts import Bar, Line
 
#柱形图
bar = (
    Bar(init_opts=opts.InitOpts(width='950px', height='600px'))   #设置柱形图宽度与高度
    .add_xaxis(['2014年','2015年','2016年','2017年','2018年','2019年','2020年','2021年'])                                
    .add_yaxis( '诊疗量(万人次)', [87430, 90912,96225,101885,107147,116390,105764,120215],
               yaxis_index=1,
               label_opts=opts.LabelOpts(is_show=False),
    )
    .extend_axis(
        yaxis=opts.AxisOpts(
            name='诊疗量(万人次)', #y轴名称
            type_='value',
            min_=0,#y轴最小值:0
            max_=150000,#y轴最大值:150000
            position='left'#位于y轴左侧
        )
    )
    .extend_axis(
        yaxis=opts.AxisOpts(
            name='同比增速(%)',#y轴名称
            type_='value',
            min_=-20,#y轴最小值
            max_=20,#y轴最大值
            position='right',#位于y轴右侧
        )
    )
    #设置全局配置项
    .set_global_opts(title_opts=opts.TitleOpts(title='2014-2021年中国中医类医疗卫生机构诊疗量'),
        legend_opts=opts.LegendOpts(pos_left='40%' ),#图例距离左边边距:40%
        tooltip_opts=opts.TooltipOpts(trigger='axis', axis_pointer_type='cross'),  #提示框
        toolbox_opts=opts.ToolboxOpts(is_show=False)  # 工具箱
    )
    #图元样式配置项
    .set_series_opts(itemstyle_opts=opts.ItemStyleOpts(               
                     opacity=0.3),#设置柱形图透明度
                     color="green",#图形的颜色
                     )
    
)
 
# 折线图
line = (
    Line()
    .add_xaxis(['2014年','2015年','2016年','2017年','2018年','2019年','2020年','2021年'])
    .add_yaxis('同比增速(%)',[7.40,4.00,5.83,5.81,5.16,8.63,-9.31,13.66],#y轴折线图数据
               yaxis_index=2,#表示y轴的索引,用于拥有多个y轴的单图表中。
               color="blue",#图形的颜色
    )
 
)
 
#层叠组件 Overlap
bar.overlap(line).render_notebook()#渲染到notebook中

展示图表如下:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值