使用pyecharts绘制柱形折线融合图,圆环图,堆积图和雷达图,并自定义布局

一、柱形折线融合图

#1、导入模块
import pyecharts.options as opts
from pyecharts.charts import Bar, Line

#准备数据
x_data = ['2014', '2015', '2016', '2017', '2018', '2019', '2020', '2021']

#2、创建Bar类对象
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=0     # 因为折线图会被柱状图遮挡,所以此处把柱状图置底
    )
 
    .extend_axis(
        yaxis=opts.AxisOpts(
            name="同比增速(%)",
            type_="value",
            min_=-20,      # 刻度标签的最大值
            max_=20,       # 刻度标签的最小值
            interval=10,   # 步长
            axislabel_opts=opts.LabelOpts(formatter="{value} %"),  # 设置刻度标签的单位
        )
    )
    
    .set_global_opts(
        tooltip_opts=opts.TooltipOpts(   
            is_show=True, trigger="axis", axis_pointer_type="cross"
        ),     # 设置提示框配置项,触发类型为坐标轴类型,指示器类型为"cross"
        xaxis_opts=opts.AxisOpts(
            type_="category",
            axispointer_opts=opts.AxisPointerOpts(is_show=True, type_="shadow"),
        ),     # 设置x轴配置项为类目轴,适用于离散的类目数据      
        yaxis_opts=opts.AxisOpts(
            name="诊疗量(万人次)",
            type_="value",
            min_=0,          # 刻度标签的最大值 
            max_=150000,     # 刻度标签的最小值
            interval=50000,  # 步长
            axislabel_opts=opts.LabelOpts(formatter="{value} 万人"),  # 设置刻度标签的单位
            axistick_opts=opts.AxisTickOpts(is_show=True),           # 显示坐标轴刻度
            splitline_opts=opts.SplitLineOpts(is_show=True),         # 显示分割线
        ),
        title_opts=opts.TitleOpts(
            is_show=True, title="2014-2021年中国中医类医疗卫生机构诊疗量", pos_left="center"
        ),     # 设置标题并将其居中
        legend_opts=opts.LegendOpts(is_show=False),  #隐藏图例配置项
    )
)


#创建Line类对象
line = (
    Line()
    .add_xaxis(xaxis_data=x_data)
    .add_yaxis(
        series_name="同比增速",
        yaxis_index=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),
        symbol="triangle",
        symbol_size=20,
    )
    .set_series_opts(
        linestyle_opts=opts.LineStyleOpts(width= 4)
    )   # 设置线条宽度为4
)

#3、渲染图表
bar.overlap(line).render_notebook()

  运行结果如下:

二、圆环图

#1、导入模块
import pyecharts.options as opts
from pyecharts.charts import Pie

#2、创建Pie类对象
pie= (
    Pie()
    .add("", [('20岁以下',2.2), ('20-30岁',27.9), ('31-40岁',56.2), ('41-50岁',10.9), ('51岁以上',2.8)], radius=[85, 160])   #添加数据
    .set_global_opts(
        title_opts=opts.TitleOpts(title="中药材消费者画像", pos_left="center")    #设置主标题并居中
        legend_opts=opts.LegendOpts(is_show=False)  #隐藏图例配置项
    )
    .set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {c}")) 
    #不同图表类型下的 {a},{b},{c},{d} 含义不一样,在这里饼图分别表示的是 {b}(数据项名称),{c}(数值)
)

#3、渲染图表
pie.render_notebook()

# radius: 饼图的半径,数组的第一项是内半径,第二项是外半径 。

 运行结果如下:

三、 堆积图

#1、导入模块
from pyecharts import options as opts
from pyecharts.charts import Bar

#添加数据
list1 = [20.3, 22.0, 23.5, 22.5, 22.3]
list2 = [79.7, 78.0, 76.5, 77.5, 77.7]

#2、创建Bar类对象
bar1 = (
    Bar()
    .add_xaxis(['2019年','2020年','2021年','2022年','2023年'])   #设置横坐标刻度标签文字
    .add_yaxis("跨国企业占比", list1, stack="stack1")   #若两个都为stack相同,则默认堆叠
    .add_yaxis("本土企业占比", list2, stack="stack1")   #若两个都为stack不同,则默认并行
    .set_series_opts(label_opts=opts.LabelOpts(is_show=False))  #隐藏标签配置项
    .set_global_opts(
        xaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(rotate=30)),   将横坐标刻度标签文字旋转30°
        title_opts=opts.TitleOpts(title="全国药店中药饮品供应商占比", pos_left="center"),  #设置主标题并居中
        legend_opts=opts.LegendOpts(is_show=False)  #隐藏图例配置项
    )
)

#3、渲染图表
bar1.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()

 # radius:雷达的半径。可以为如下类型: 

·1、number:直接指定外半径值。  ·2、string:例如,'20%',表示外半径为可视区尺寸(容器高宽中较 小一项)的 20% 长度。  ·3、Array.<number|string>:数组的第一项是内半径,第二项是外半径。每一项遵从上述 number string 的描述。

运行结果如下:

 自定义布局

自定义布局我用的是顺序多图,pyecharts.charts的Page类表示顺序显示的组合图表,它可以在同一网页中按顺序渲染多个图表。其中Page(layout=Page.DraggablePageLayout)可以让我们手动调节各个图表在网页中的布局。

代码如下:

import pyecharts.options as opts
from pyecharts.charts import Bar, Line, Radar, Pie, Grid, Page


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=0
    )

    .extend_axis(
        yaxis=opts.AxisOpts(
            name="同比增速(%)",
            type_="value",
            min_=-20,
            max_=20,
            interval=10,
            axislabel_opts=opts.LabelOpts(formatter="{value} %"),
        )
    )
    
    .set_global_opts(
        tooltip_opts=opts.TooltipOpts(
            is_show=True, trigger="axis", axis_pointer_type="cross"
        ),
        xaxis_opts=opts.AxisOpts(
            type_="category",
            axispointer_opts=opts.AxisPointerOpts(is_show=True, type_="shadow"),
        ),
        yaxis_opts=opts.AxisOpts(
            name="诊疗量(万人次)",
            type_="value",
            min_=0,
            max_=150000,
            interval=50000,
            axislabel_opts=opts.LabelOpts(formatter="{value} "),
            axistick_opts=opts.AxisTickOpts(is_show=True),
            splitline_opts=opts.SplitLineOpts(is_show=True),
        ),
        title_opts=opts.TitleOpts(
            is_show=True, title="2014-2021年中国中医类医疗卫生机构诊疗量", pos_left="center"
        ),
        legend_opts=opts.LegendOpts(
            is_show=False
        )
    )
)


line = (
    Line()
    .add_xaxis(xaxis_data=x_data)
    .add_yaxis(
        series_name="同比增速",
        yaxis_index=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),
        symbol="triangle",
        symbol_size=20,
    )
    .set_series_opts(
        linestyle_opts=opts.LineStyleOpts(width= 4)
    )
)

pie= (
    Pie()
    .add("", [('20岁以下',2.2), ('20-30岁',27.9), ('31-40岁',56.2), ('41-50岁',10.9), ('51岁以上',2.8)], radius=[85, 160])
    .set_global_opts(
        title_opts=opts.TitleOpts(title="中药材消费者画像"),
        legend_opts=opts.LegendOpts(is_show=False),
    )
    .set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {c}"))
)



list1 = [20.3, 22.0, 23.5, 22.5, 22.3]
list2 = [79.7, 78.0, 76.5, 77.5, 77.7]
bar1 = (
    Bar()
    .add_xaxis(['2019年','2020年','2021年','2022年','2023年'])
    .add_yaxis("跨国企业占比", list1, stack="stack1")
    .add_yaxis("本土企业占比", list2, stack="stack1")
    .set_series_opts(label_opts=opts.LabelOpts(is_show=False))
    .set_global_opts(
        xaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(rotate=30)),
        title_opts=opts.TitleOpts(title="全国药店中药饮品供应商占比", pos_left="center"),
        legend_opts=opts.LegendOpts(is_show=False)
    )
)

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},
]

radar = (
    Radar()
    .set_colors(["#4587E7"])
    .add_schema(
        schema=c_schema,
        shape="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")
                    )
)

overlap_1 = bar.overlap(line)

page = (
    Page(layout=Page.DraggablePageLayout)
    .add(overlap_1)
    .add(pie)
    .add(bar1)
    .add(radar)
)


page.render("自定义布局.html")

 运行结果如下:(下图是经过本人手动调节过的)

  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值