基于pyecharts,用一张独立画布,柱形图和折线图融合在同一个坐标系

  一、绘制2014-2021年中国中医类医疗卫生机构诊疗量柱形图与折现图的融合

import pyecharts.options as opts
from pyecharts.charts import Bar,Line,Scatter,Pie
 
x_data = ['2014年','2015年','2016年','2017年','2018年','2019年','2020年','2021年']
 
bar = (
    Bar()
    .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 =2,
     )
    .set_global_opts(title_opts=opts.TitleOpts(title='2014-2021年中国中医类医疗卫生机构诊疗量', pos_left='center'),legend_opts=opts.LegendOpts(is_show=False))
   
    .extend_axis(
        yaxis=opts.AxisOpts(
            name="同比增速(%)",
            type_="value",
            min_=-20,
            max_=20,
            interval=10,
            axislabel_opts=opts.LabelOpts(formatter="{value} "),
        )
    )
)
 
line = (
    Line()
    .add_xaxis(xaxis_data=x_data)
    .add_yaxis(
        series_name='诊疗量(万人次)',
        # 使用的 y 轴的 index,在单个图表实例中存在多个 y 轴的时候有用。
        yaxis_index=1,  #  第一条y轴索引为0,第二条y轴索引为1
        y_axis=[7.40,4.00,5.83,5.81,5.16,8.63,-9.13,13.66],
        label_opts=opts.LabelOpts(is_show=False),
        z = 3,  # z值小的图形会被z值大的图形覆盖
    )
     
)
 
 
 
 
 
bar.overlap(line).render_notebook()  # 柱形图 层叠 折线图

 运行效果如下

二、绘制圆环图

from pyecharts import options as opts
from pyecharts.charts import Page, Pie
 
#往该实例填充数据
data = [['20岁以下', 40], ['20-30岁', 50], ['31-40岁', 70], ['41-50岁', 30],['51岁以上',50]]
c = (Pie()
.add("",data,radius=["20%", "35%"])   
# 圆环的粗细和大小
.set_global_opts( title_opts=opts.TitleOpts(title="中药材消费者画像数据"),legend_opts=opts.LegendOpts(is_show=False),toolbox_opts=opts.ToolboxOpts(is_show=True))
.set_series_opts(label_opts=opts.LabelOpts(formatter="{b}")))
#  展示图表(渲染图表)
c.render_notebook()

 运行效果如下

三、绘制堆积图 

# 柱状堆叠图
import random
import pyecharts.options as opts
from pyecharts.charts import Bar
 
goods = ['2019年', '2020年', '2021年', '2022年', '2023年']
bar = (
    Bar()
    .add_xaxis(goods)
    .add_yaxis('', [random.randint(6, 60) for _ in range(6)], stack='stack1',bar_width="40%")
    .add_yaxis('', [random.randint(6, 60) for _ in range(6)], stack='stack1',bar_width="40%",color='orange')
#     .add_yaxis('', [random.randint(10, 100) for _ in range(6)], stack='stack1')
    .set_series_opts(label_opts=opts.LabelOpts(is_show=False))
    .set_global_opts(title_opts=opts.TitleOpts(title='全国药店中药饮片供应商占比情况', pos_top="5%",pos_bottom="80%",pos_left="30%",pos_right="45%"),
                     xaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(rotate=35)),
                     #xaxis_opts=opts.AxisOpts(name='品类'),       
                     #yaxis_opts=opts.AxisOpts(name='销量(单位:件)'))
)
)
#展示图表(渲染图表)
bar.render_notebook()

 运行效果如下

 四、绘制全国药店药品销售额占比的雷达图

#1、导入模块
import pyecharts.options as opts
from pyecharts.charts import Radar
 
#添加数据
data = [{"value": [45, 3, 9, 4, 6, 33], "name": "销售占比"}]
c_schema = [
    {"name": "中成药", "max": 50, "min": 0},    #设置指示器名称、最大值和最小值
    {"name": "生物制品", "max": 50, "min": 0},
    {"name": "医疗器械", "max": 50, "min": 0},
    {"name": "保健品", "max": 50, "min": 0},
    {"name": "中药饮片", "max": 50, "min": 0},
    {"name": "化学药", "max": 50, "min": 0},
]
 
#2、创建Radar类对象
radar = (
    Radar()
    .set_colors(["#4587E7"])   #设置颜色
    .add_schema(
        schema=c_schema,   # 雷达指示器配置项列表
        shape="circle",    # 雷达图绘制类型,可选 'polygon' 和 'circle'
        center=["50%", "50%"],  #雷达的中心(圆心)坐标,数组的第一项是横坐标,第二项是纵坐标。
        radius="80%",
        angleaxis_opts=opts.AngleAxisOpts(
            min_=0,
            max_=360,
            is_clockwise=False,
            interval=5,
            axistick_opts=opts.AxisTickOpts(is_show=False),
            axislabel_opts=opts.LabelOpts(is_show=False),
            axisline_opts=opts.AxisLineOpts(is_show=False),
            splitline_opts=opts.SplitLineOpts(is_show=False),
        ),
        radiusaxis_opts=opts.RadiusAxisOpts(   #极坐标系的角度轴
            min_=0,
            max_=50,
            interval=10,
            splitarea_opts=opts.SplitAreaOpts(
                is_show=True, areastyle_opts=opts.AreaStyleOpts(opacity=1)
            ),
        ),
        polar_opts=opts.PolarOpts(),
        splitarea_opt=opts.SplitAreaOpts(is_show=False),
        splitline_opt=opts.SplitLineOpts(is_show=False),
    )
    .add(
        series_name="销售占比",
        data=data,
        areastyle_opts=opts.AreaStyleOpts(opacity=0.1),  #设置区域填充样式配置项
        linestyle_opts=opts.LineStyleOpts(width=1),      #设置线样式配置项
    )
    .set_global_opts( legend_opts=opts.LegendOpts(is_show=False),  #隐藏图例配置项
                      title_opts=opts.TitleOpts(title="全国药店中药饮品供应商占比", pos_left="center"))    #设置标题并居中
)
 
#3、渲染图表
radar.render_notebook()

运行效果如下 五、将柱形图-折线图,圆环图,堆积柱形图绘制在同一张表中

# 导入需要用到的图表类
from pyecharts import options as opts
from pyecharts.charts import Bar, Grid, Line,Pie,Radar
 
#1.绘制柱形图
#x轴数据
x_data = ["2014","2015","2016","2017","2018","2019","2020","2021"]
 
#标签名
legend_list = ["诊疗量(万人次)",  "同比增速(%)"]
 
#"诊疗量(万人次)"的数据
value1 =[87430, 90912,96225,101885,107147,116390,105764,120215] 
 
#"同比增速(%)的数据
value2 = [7.40,4.00,5.83,5.81,5.16,8.63,-9.31,13.66]
 
#绘制柱形图
bar = (
    Bar(init_opts=opts.InitOpts(width="1000px", height="500px"))   #设置柱形图宽度与高度
    .add_xaxis(xaxis_data=x_data)                                  #添加x轴的数据
    .add_yaxis(                                                    
        series_name="诊疗量(万人次)",                            #图例名:诊疗量(万人次)
        y_axis=value1,                                             ##y轴柱形图数据
        yaxis_index=1,                                             #表示y轴的索引,用于拥有多个y轴的单图表中。
#         label_opts=opts.LabelOpts(is_show=False),                 #不显示柱形图数据
        color='pink',
        z=0
    )
    .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轴最小值:-20
            max_=20,                                              #y轴最大值:20
            position="right",                                     #位于y轴右侧
        )
    )
    .set_global_opts(                                             #设置全局配置项
        title_opts=opts.TitleOpts(title="2014-2021年中国中医类医疗卫生机构诊疗量",
                                 pos_left='center'),      #标题名称
        legend_opts=opts.LegendOpts(is_show=False),      #不显示图例                    
        tooltip_opts=opts.TooltipOpts(trigger="axis", axis_pointer_type="cross"),  #显示提示框组件
    )
    .set_series_opts(
                     itemstyle_opts=opts.ItemStyleOpts(               #图元样式配置项
                     opacity=0.5),                                    #设置柱形图透明度:0.5
                     )
    
)
# 绘制折线图
 
line = (
    Line()                                                           #创建Line类的对象
    .add_xaxis(x_data)                                               #添加x轴的数据
    .add_yaxis(
        series_name="同比增速(%)",                                #图例名:同比增速(%)
        y_axis=value2,                                              #y轴折线图数据
        yaxis_index=2,                                              #表示y轴的索引,用于拥有多个y轴的单图表中。
)
    .set_series_opts(
        linestyle_opts=opts.LineStyleOpts(width= 2)
    )
)
 
 
 
#3.堆积柱形图
x_data=['2019年','2020年','2021年','2022年','2023年']
data1 = [20.3,22.0,23.5,22.5,22.3]   # 跨国企业占比
data2 = [79.7,78.0,76.5,77.5,77.7]  # 本土企业占比
 
stack = (
    Bar()
    .add_xaxis(x_data)
    .add_yaxis("跨国企业占比", data1, stack="stack1", category_gap="20%",    #stack="stack1":堆积柱形图
                xaxis_index=1, 
                yaxis_index=3,
               label_opts=opts.LabelOpts(is_show=False)                #不显示柱形图数据
              )                
    .add_yaxis("本土企业占比", data2, stack="stack1", category_gap="80%",
                xaxis_index=1, 
                yaxis_index=3,
              label_opts=opts.LabelOpts(is_show=False)                #不显示柱形图数据
              )  
    .set_global_opts(                                             #设置全局配置项
        title_opts=opts.TitleOpts(title="全国药店中药饮片供应商占比", #标题名称
                                 pos_left='34%',
                                 pos_top="52%"),     
        legend_opts=opts.LegendOpts(is_show=False ),                        #不显示图例
        tooltip_opts=opts.TooltipOpts(trigger="axis", axis_pointer_type="cross"),  #显示提示框组件
        yaxis_opts=opts.AxisOpts(min_=0,max_=100,                                  #y轴刻度范围0—100
                              interval=25                                          #y轴刻度范围分为25一组
                                            ),
        xaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(rotate=45)         #x轴标签旋转45°
                                 )
                     ) 
        )
 
 
# 注意:绘制环形图(放在堆积图后面)
#添加标签与数值
labels=[('20岁以下',2.2),
        ('20-30岁',27.9),
        ('31-40岁',56.2),
        ('41-50岁',10.9),
        ('51岁以上',2.8)]
 
 #  准备数据
data = [['20岁以下', 40], ['20-30岁', 50], ['31-40岁', 70], ['41-50岁', 30],['51岁以上',50]]
 
# 绘制圆环图
pie = (
    Pie()
    .add("", data ,
        radius=["20%", "35%"], # 挖掉的直径,整张饼的直径 (百分数指的是占画布中高和宽中小的那一项的比例)
         center=["20%","80%"]
        )
    .set_global_opts(
       title_opts=opts.TitleOpts(title="中药材消费者画像数据", pos_top="50%",pos_bottom="30%",pos_left="10%",pos_right="90%"),
        legend_opts=opts.LegendOpts(is_show=False,pos_top="20%"),
        
                     
)
      
                                   
        )
 
 
c=bar.overlap(line)    #柱形图-折线融合(放在其他实例后面,不然会排版错乱)
 
 
 
 
#5.创建一个组合图表实例(数据填充格式为:其他图表实例,Bar,Line,Pie,Scatter)
grid = (
    Grid()         #GridOpts:直角坐标系网格配置项
    .add( c,
         grid_opts=opts.GridOpts(pos_bottom="60%"),            #grid 组件离容器下侧的距离        
                                 is_control_axis_index=True   
        )  
    
    .add(stack, 
         grid_opts=opts.GridOpts(pos_bottom="10%",
                                 pos_top="60%",
                                 pos_left="35%",
                                 pos_right="40%"
                                ),
                                 is_control_axis_index=True
        )
 
    .add(pie, 
         grid_opts=opts.GridOpts(pos_bottom="5%",
                                 pos_top="60%",
                                 pos_left="10%",
                                 pos_right="90%"
                                ),
                                 is_control_axis_index=True
        )
 
    
    
         )
#     通过联合调整pos_bottom,pos_top,pos_left, pos_right 这四个参数,实现并行组合图表中的任意布局
 
grid.render_notebook()

 效果如下图

  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 Pyecharts 中的 Grid(网格)组件来实现在一个画布中绘制两个图表的效果,其中柱形图折线图分别对应网格中的左边和右边。 以下是一个示例代码: ```python from pyecharts import options as opts from pyecharts.charts import Bar, Line, Grid # 创建柱形图 bar = ( Bar() .add_xaxis(['A', 'B', 'C', 'D', 'E']) .add_yaxis('柱形图', [5, 20, 36, 10, 75]) .set_global_opts(title_opts=opts.TitleOpts(title='柱形图')) ) # 创建折线图 line = ( Line() .add_xaxis(['A', 'B', 'C', 'D', 'E']) .add_yaxis('折线图', [15, 30, 46, 20, 95], yaxis_index=1) .set_global_opts(title_opts=opts.TitleOpts(title='折线图')) ) # 使用网格组件将柱形图折线图合并到一个画布中 grid = ( Grid() .add(bar, grid_opts=opts.GridOpts(pos_left='5%', pos_right='50%')) .add(line, grid_opts=opts.GridOpts(pos_left='55%', pos_right='5%')) ) # 渲染图表 grid.render('bar_and_line.html') ``` 上述代码中,首先创建了一个柱形图和一个折线图柱形图使用 `Bar` 类创建,折线图使用 `Line` 类创建,它们都通过 `add_xaxis` 和 `add_yaxis` 方法设置了横坐标和纵坐标的数据。需要注意的是,折线图的纵坐标需要通过 `yaxis_index` 参数指定为右边的纵坐标轴。 接下来使用 `Grid` 类创建了一个网格组件,通过 `add` 方法将柱形图折线图添加到网格中,设置了两个网格的位置,其中柱形图占据了左边的网格,折线图占据了右边的网格。 最后调用 `render` 方法将图表渲染为 HTML 文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值