Python可视化神器pyecharts之绘制箱形图


Posted in Python onJuly 07, 2022

箱形图

概念

后面的图形都是一些专业的统计图形,当然也会是我们可视化的对象。

箱形图(Box-plot)又称为盒须图、盒式图或箱线图,是一种用作显示一组数据分散情况资料的统计图。因形状如箱子而得名。在各种领域也经常被使用,常见于​ ​品质管理​​。它主要用于反映原始数据分布的特征,还可以进行多组数据分布特征的比 较。箱线图的绘制方法是:先找出一组数据的上边缘、下边缘、中位数和两个四分位数;然后, 连接两个四分位数画出箱体;再将上边缘和下边缘与箱体相连接,中位数在箱体中间。

Python可视化神器pyecharts之绘制箱形图

 用处

1.直观明了地识别数据批中的异常值

上文讲了很久的识别异常值,其实箱线图判断异常值的标准以四分位数和四分位距为基础,四分位数具有一定的耐抗性,多达25%的数据可以变得任意远而不会很大地扰动四分位数,所以异常值不会影响箱形图的数据形状,箱线图识别异常值的结果比较客观。由此可见,箱线图在识别异常值方面有一定的优越性。

2.利用箱线图判断数据批的偏态和尾重

对于标准正态分布的样本,只有极少值为异常值。异常值越多说明尾部越重,自由度越小(即自由变动的量的个数);

而偏态表示偏离程度,异常值集中在较小值一侧,则分布呈左偏态;异常值集中在较大值一侧,则分布呈右偏态。

3.利用箱线图比较几批数据的形状

同一数轴上,几批数据的箱线图并行排列,几批数据的中位数、尾长、异常值、分布区间等形状信息便昭然若揭。如上图,可直观得看出第三季度各分公司的销售额大体都在下降。

箱形图系列模板

第一个箱形图

说实话这类图形的绘制,如果不懂专业的知识可能也无法理解,对于如何深层次的理解这个图形的具体含义,请移步到其他专栏,我会详细介绍,这里就不做过多的解释了。

from pyecharts import options as opts
from pyecharts.charts import Boxplot
v1 = [
[850, 740, 900, 1070, 930, 850, 950, 980, 980, 880, 1000, 980],
[960, 940, 960, 940, 880, 800, 850, 880, 900, 840, 830, 790],
]
v2 = [
[890, 810, 810, 820, 800, 770, 760, 740, 750, 760, 910, 920],
[890, 840, 780, 810, 760, 810, 790, 810, 820, 850, 870, 870],
]
c = Boxplot()
c.add_xaxis(["expr1", "expr2"])
c.add_yaxis("A", c.prepare_data(v1))
c.add_yaxis("B", c.prepare_data(v2))
c.set_global_opts(title_opts=opts.TitleOpts(title="标题"))
c.render("简单示例.html")
print(c.prepare_data(v1))

Python可视化神器pyecharts之绘制箱形图

复杂一点的图例

import pyecharts.options as opts
from pyecharts.charts import Grid, Boxplot, Scatter

y_data = [
[
850,
740,
900,
1070,
930,
850,
950,
980,
980,
880,
1000,
980,
930,
650,
760,
810,
1000,
1000,
960,
960,
],
[
960,
940,
960,
940,
880,
800,
850,
880,
900,
840,
830,
790,
810,
880,
880,
830,
800,
790,
760,
800,
],
[
880,
880,
880,
860,
720,
720,
620,
860,
970,
950,
880,
910,
850,
870,
840,
840,
850,
840,
840,
840,
],
[
890,
810,
810,
820,
800,
770,
760,
740,
750,
760,
910,
920,
890,
860,
880,
720,
840,
850,
850,
780,
],
[
890,
840,
780,
810,
760,
810,
790,
810,
820,
850,
870,
870,
810,
740,
810,
940,
950,
800,
810,
870,
],
]
scatter_data = [650, 620, 720, 720, 950, 970]

box_plot = Boxplot()

box_plot = (
box_plot.add_xaxis(xaxis_data=["expr 0", "expr 1", "expr 2", "expr 3", "expr 4"])
.add_yaxis(series_name="", y_axis=box_plot.prepare_data(y_data))
.set_global_opts(
title_opts=opts.TitleOpts(
pos_left="center", title="Michelson-Morley Experiment"
),
tooltip_opts=opts.TooltipOpts(trigger="item", axis_pointer_type="shadow"),
xaxis_opts=opts.AxisOpts(
type_="category",
boundary_gap=True,
splitarea_opts=opts.SplitAreaOpts(is_show=False),
axislabel_opts=opts.LabelOpts(formatter="expr {value}"),
splitline_opts=opts.SplitLineOpts(is_show=False),
),
yaxis_opts=opts.AxisOpts(
type_="value",
name="km/s minus 299,000",
splitarea_opts=opts.SplitAreaOpts(
is_show=True, areastyle_opts=opts.AreaStyleOpts(opacity=1)
),
),
)
.set_series_opts(tooltip_opts=opts.TooltipOpts(formatter="{b}: {c}"))
)

scatter = (
Scatter()
.add_xaxis(xaxis_data=["expr 0", "expr 1", "expr 2", "expr 3", "expr 4"])
.add_yaxis(series_name="", y_axis=scatter_data)
.set_global_opts(
title_opts=opts.TitleOpts(
pos_left="10%",
pos_top="90%",
title="upper: Q3 + 1.5 * IQR \nlower: Q1 - 1.5 * IQR",
title_textstyle_opts=opts.TextStyleOpts(
border_color="#999", border_width=1, font_size=14
),
),
yaxis_opts=opts.AxisOpts(
axislabel_opts=opts.LabelOpts(is_show=False),
axistick_opts=opts.AxisTickOpts(is_show=False),
),
)
)
grid = (
Grid(init_opts=opts.InitOpts(width="1200px", height="600px"))
.add(
box_plot,
grid_opts=opts.GridOpts(pos_left="10%", pos_right="10%", pos_bottom="15%"),
)
.add(
scatter,
grid_opts=opts.GridOpts(pos_left="10%", pos_right="10%", pos_bottom="15%"),
)
.render("第一个箱形图.html")
)

Python可视化神器pyecharts之绘制箱形图

其实对于这个图形的绘制我个人觉得掌握好一定技巧,绘制图形并不难,主要是你要知道一定数据分析方法,不然空谈数据可视也是枉然。

到此这篇关于Python可视化神器pyecharts之绘制箱形图的文章就介绍到这了,更多相关Python绘制箱形图内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!


Tags in this post...

Python 相关文章推荐
python通过imaplib模块读取gmail里邮件的方法
May 08 Python
Python编程修改MP3文件名称的方法
Apr 19 Python
pycharm远程调试openstack代码
Nov 21 Python
Python模块文件结构代码详解
Feb 03 Python
TensorFlow实现iris数据集线性回归
Sep 07 Python
详解django的serializer序列化model几种方法
Oct 16 Python
python数值基础知识浅析
Nov 19 Python
在notepad++中实现直接运行python代码
Dec 18 Python
pytorch 多分类问题,计算百分比操作
Jul 09 Python
Python如何给函数库增加日志功能
Aug 04 Python
详解PyQt5中textBrowser显示print语句输出的简单方法
Aug 07 Python
PyCharm+PyQt5+QtDesigner配置详解
Aug 12 Python
Python通用验证码识别OCR库ddddocr的安装使用教程
Jul 07 #Python
Django数据库(SQlite)基本入门使用教程
Jul 07 #Python
Python可视化神器pyecharts之绘制地理图表练习
Django中celery的使用项目实例
Python可视化神器pyecharts绘制地理图表
Python软件包安装的三种常见方法
Python+SeaTable实现计算两个日期间的工作日天数
Jul 07 #Python
You might like
PHP实现linux命令tail -f
2016/02/22 PHP
php版阿里大于(阿里大鱼)短信发送实例详解
2016/11/30 PHP
静态页面的值传递(三部曲)
2006/09/25 Javascript
JavaScript 学习笔记(六)
2009/12/31 Javascript
jQuery 关于伪类选择符的使用说明
2013/04/24 Javascript
javascript实现促销倒计时+fixed固定在底部
2013/09/18 Javascript
简单谈谈javascript代码复用模式
2015/01/28 Javascript
全面理解JavaScript中的继承(必看)
2016/06/16 Javascript
图解prototype、proto和constructor的三角关系
2016/07/31 Javascript
js实现下一页页码效果
2017/03/07 Javascript
React服务端渲染(总结)
2017/07/01 Javascript
JavaScript自执行函数和jQuery扩展方法详解
2017/10/27 jQuery
iview table render集成switch开关的实例
2018/03/14 Javascript
在Python中关于中文编码问题的处理建议
2015/04/08 Python
python 网络编程常用代码段
2016/08/28 Python
用pandas中的DataFrame时选取行或列的方法
2018/07/11 Python
Empty test suite.(PyCharm程序运行错误的解决方法)
2018/11/30 Python
python getopt模块使用实例解析
2019/12/18 Python
Python数据可视化实现多种图例代码详解
2020/07/14 Python
python 解决pycharm运行py文件只有unittest选项的问题
2020/09/01 Python
Under Armour瑞典官方网站:美国高端运动科技品牌
2018/11/21 全球购物
英国独特家具和家庭用品购物网站:Cuckooland
2020/08/30 全球购物
TecoBuy澳大利亚:在线电子和小工具商店
2020/06/25 全球购物
会计自我鉴定
2013/11/02 职场文书
工作自我评价分享
2013/12/01 职场文书
初二物理教学反思
2014/01/29 职场文书
四年大学自我鉴定
2014/02/17 职场文书
《中国梦我的梦》小学生演讲稿
2014/08/20 职场文书
高中生自我评价范文2015
2015/03/03 职场文书
现役军人家属慰问信
2015/03/24 职场文书
JS实现扫雷项目总结
2021/05/19 Javascript
MySQL系列之二 多实例配置
2021/07/02 MySQL
JavaScript实现栈结构详细过程
2021/12/06 Javascript
微软官方消息,在 2023 年 4 月 11 日之后微软将不再为 Office 2013 和 Skype for Business 2015 提供安全更新
2022/04/21 数码科技
MySQL安装失败的原因及解决步骤
2022/06/14 MySQL
Win11怎么添加用户?Win11添加用户账户的方法
2022/07/15 数码科技