Echarts箱线图

在这里插入图片描述

<!DOCTYPE HTML>
<html>
<head>
	<style type="text/css">
		#main{
			height: 500px;
			border: 1px red solid;
			width: 100%;
		}
	</style>
	<script type="text/javascript" src="E:/IdeaWorkSpace/MyLib/js/jquery-1.12.0.min.js"></script>
	<script type="text/javascript" src="E:/IdeaWorkSpace/MyLib/js/echarts.min.js"></script>
	<script type="text/javascript" src="E:/IdeaWorkSpace/MyLib/js/dataTool.js"></script>
	
	<script type="text/javascript">
		$(function() {
			debugger
				// 基于准备好的dom,初始化echarts实例
				var myChart = echarts.init(document.getElementById('main'));
				var data = echarts.dataTool.prepareBoxplotData([
					[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]
				]);
				var testData = [[-4450.50,25041.00,31060.00,38768.00,59358.50],[-268704.00,321546.00,399121.00,715046.00,1305296.00],[514960.00,514960.00,514960.00,514960.00,514960.00]];


				debugger
				var a = data.boxData
				console.log(a)
				
				option = {
					title: [{
							text: '项目: 钾',
							left: 'center',
							textStyle: {
								fontSize: 20,
								color: 'green',
							},
						},
						{
							text: '批号',
							//borderColor: '#999',
							//borderWidth: 1,
							textStyle: {
								fontSize: 14
							},
							left: 'center',
							top: '94%'
						},
						{
							text: 'upper: Q3 + 1.5 * IRQ \nlower: Q1 - 1.5 * IRQ',
							borderColor: '#999',
							borderWidth: 1,
							textStyle: {
								fontSize: 14
							},
							left: '10%',
							top: '90%'
						}
					],
					tooltip: {
						trigger: 'item', //触发类型,数据项图形触发,主要在散点图,饼图等无类目轴的图表中使用。
						axisPointer: { //指示器类型。
							type: 'shadow'
						}
					},
					grid: { //直角坐标系网格。
						//show: true,//default: false
						left: '10%',
						right: '10%',
						bottom: '15%',
						//borderWidth: 1,
						//borderColor: '#000',	
					},
					xAxis: { //X轴
						type: 'category', //'category' 类目轴,适用于离散的类目数据,为该类型时必须通过 data 设置类目数据。
						//data: data.axisData,
						data: ['周一', '周二', '周三', '周四', '周五'],
						boundaryGap: true, //类目轴中 boundaryGap 可以配置为 true 和 false。默认为 true,这时候刻度只是作为分隔线,标签和数据点都会在两个刻度之间的带(band)中间。
						nameGap: 30, //坐标轴名称与轴线之间的距离。
						splitArea: { //坐标轴在 grid 区域中的分隔区域,默认不显示。
							//show: true, //是否显示分隔区域
							//interval: 'auto', //坐标轴分隔区域的显示间隔,在类目轴中有效
						},
						axisLabel: { //坐标轴刻度标签的相关设置。
							//formatter: 'expr {value}',  // 使用字符串模板,模板变量为刻度默认标签 {value}						
							show: true, //是否显示刻度标签。
							//interval: 'auto', //坐标轴刻度标签的显示间隔,在类目轴中有效。
							color: 'black',
 
						},
						splitLine: { //坐标轴在 grid 区域中的分隔线。
							show: true, //是否显示分隔线。默认数值轴显示,类目轴不显示。
							lineStyle: { //分隔线样式
								type: 'dashed', //分隔线线的类型。								
							},
						},
						axisLine: { //坐标轴轴线相关设置。
							show: true, //是否显示坐标轴轴线。
							//onZero:false,//X 轴或者 Y 轴的轴线是否在另一个轴的 0 刻度上,只有在另一个轴为数值轴且包含 0 刻度时有效。
							//symbol:'arrow', //轴线两边的箭头, 默认不显示箭头,即 'none'
							lineStyle: { //轴线样式
								width: 2,
								color: 'green',
								//opacity: 1, //图形透明度。支持从 0 到 1 的数字,为 0 时不绘制该图形。
							},
						},
						axisTick: { //坐标轴刻度相关设置。
							show: true, //是否显示坐标轴刻度。
							//alignWithLabel: true,//类目轴中在 boundaryGap 为 true 的时候有效,可以保证刻度线和标签对齐,default: false							
 
						}
					},
					yAxis: { //y轴
						type: 'value',
						splitArea: { //坐标轴在 grid 区域中的分隔区域,默认不显示。
							//show: true
						},
						axisLabel: { //坐标轴刻度标签的相关设置。
							//formatter: 'expr {value}',  // 使用字符串模板,模板变量为刻度默认标签 {value}						
							show: true, //是否显示刻度标签。
							//interval: 'auto', //坐标轴刻度标签的显示间隔,在类目轴中有效。
							color: 'black',
						},
						splitLine: {
							show: true,
							lineStyle: {
								type: 'dashed'
							},
						},
						axisLine: {
							show: true, //是否显示坐标轴轴线。
							//onZero:false,//X 轴或者 Y 轴的轴线是否在另一个轴的 0 刻度上,只有在另一个轴为数值轴且包含 0 刻度时有效。
							//symbol:'arrow', //轴线两边的箭头
							lineStyle: {
								width: 2,
								color: 'green',
							},
						},
					},
					series: [
						{
							name: 'boxplot',//箱形图
							type: 'boxplot',
							//legendHoverLink: true, //是否启用图例 hover 时的联动高亮。
							//hoverAnimation: false, //是否开启 hover 在 box 上的动画效果。
							itemStyle: { //盒须图样式。
								//color: '#fff', //boxplot图形的颜色。 默认从全局调色盘 option.color 获取颜色
								borderColor: 'blue', //boxplot图形的描边颜色。支持的颜色格式同 color,不支持回调函数。
							},
							data: testData,
							tooltip: { //注意:series.tooltip 仅在 tooltip.trigger 为 'item' 时有效。
								formatter: function(param) {
									/*
										第一个参数 param 是 formatter 需要的数据集。 格式如下: 
										{
											//组件类型
											componentType: 'series',
											// 系列类型
											seriesType: string,
											// 系列在传入的 option.series 中的 index
											seriesIndex: number,
											// 系列名称
											seriesName: string,
											// 数据名,类目名
											name: string,
											// 数据在传入的 data 数组中的 index
											dataIndex: number,
											// 处理过的数据项
											data: Object | Array,
											// 处理过的数据项
											value: number | Array,
											// 数据图形的颜色
											color: string,
	
											// 饼图的百分比
											percent: number,
	
										}
									*/
									
									return [
										'类目名 ' + param.name + ': ',
										'upper: ' + param.data[5],
										'Q3: ' + param.data[4],
										'median: ' + param.data[3],
										'Q1: ' + param.data[2],
										'lower: ' + param.data[1]
									].join('<br/>')
								}
							}
						},
						{
							name: '异常值',//异常值
							type: 'scatter',//分散
							data: data.outliers
						}
					]
				};
 
				//myChart.showLoading(); //数据加载完之前先显示一段简单的loading动画
				// 使用刚指定的配置项和数据显示图表。
				myChart.setOption(option);
			});

	</script>
</head>

<body>
<div id="main">
</div>
</body>
</html>

dataTool.js内容如下

!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("echarts")):"function"==typeof define&&define.amd?define(["echarts"],t):"object"==typeof exports?exports.dataTool=t(require("echarts")):(e.echarts=e.echarts||{},e.echarts.dataTool=t(e.echarts))}(this,function(e){return function(e){function t(o){if(r[o])return r[o].exports;var n=r[o]={exports:{},id:o,loaded:!1};return e[o].call(n.exports,n,n.exports,t),n.loaded=!0,n.exports}var r={};return t.m=e,t.c=r,t.p="",t(0)}([function(e,t,r){var o;o=function(e){var t=r(1);return t.dataTool={version:"1.0.0",gexf:r(5),prepareBoxplotData:r(6)},t.dataTool}.call(t,r,t,e),!(void 0!==o&&(e.exports=o))},function(t,r){t.exports=e},,,,function(e,t,r){var o;o=function(e){"use strict";function t(e){var t;if("string"==typeof e){var r=new DOMParser;t=r.parseFromString(e,"text/xml")}else t=e;if(!t||t.getElementsByTagName("parsererror").length)return null;var i=l(t,"gexf");if(!i)return null;for(var u=l(i,"graph"),s=o(l(u,"attributes")),c={},f=0;f<s.length;f++)c[s[f].id]=s[f];return{nodes:n(l(u,"nodes"),c),links:a(l(u,"edges"))}}function o(e){return e?s.map(u(e,"attribute"),function(e){return{id:i(e,"id"),title:i(e,"title"),type:i(e,"type")}}):[]}function n(e,t){return e?s.map(u(e,"node"),function(e){var r=i(e,"id"),o=i(e,"label"),n={id:r,name:o,itemStyle:{normal:{}}},a=l(e,"viz:size"),s=l(e,"viz:position"),c=l(e,"viz:color"),f=l(e,"attvalues");if(a&&(n.symbolSize=parseFloat(i(a,"value"))),s&&(n.x=parseFloat(i(s,"x")),n.y=parseFloat(i(s,"y"))),c&&(n.itemStyle.normal.color="rgb("+[0|i(c,"r"),0|i(c,"g"),0|i(c,"b")].join(",")+")"),f){var p=u(f,"attvalue");n.attributes={};for(var v=0;v<p.length;v++){var d=p[v],g=i(d,"for"),h=i(d,"value"),b=t[g];if(b){switch(b.type){case"integer":case"long":h=parseInt(h,10);break;case"float":case"double":h=parseFloat(h);break;case"boolean":h="true"==h.toLowerCase()}n.attributes[g]=h}}}return n}):[]}function a(e){return e?s.map(u(e,"edge"),function(e){var t=i(e,"id"),r=i(e,"label"),o=i(e,"source"),n=i(e,"target"),a={id:t,name:r,source:o,target:n,lineStyle:{normal:{}}},u=a.lineStyle.normal,s=l(e,"viz:thickness"),c=l(e,"viz:color");return s&&(u.width=parseFloat(s.getAttribute("value"))),c&&(u.color="rgb("+[0|i(c,"r"),0|i(c,"g"),0|i(c,"b")].join(",")+")"),a}):[]}function i(e,t){return e.getAttribute(t)}function l(e,t){for(var r=e.firstChild;r;){if(1==r.nodeType&&r.nodeName.toLowerCase()==t.toLowerCase())return r;r=r.nextSibling}return null}function u(e,t){for(var r=e.firstChild,o=[];r;)r.nodeName.toLowerCase()==t.toLowerCase()&&o.push(r),r=r.nextSibling;return o}var s=r(1).util;return{parse:t}}.call(t,r,t,e),!(void 0!==o&&(e.exports=o))},function(e,t,r){var o;o=function(e){var t=r(7),o=r(1).number;return function(e,r){r=r||[];for(var n=[],a=[],i=[],l=r.boundIQR,u=0;u<e.length;u++){i.push(u+"");var s=o.asc(e[u].slice()),c=t(s,.25),f=t(s,.5),p=t(s,.75),v=p-c,d="none"===l?s[0]:c-(null==l?1.5:l)*v,g="none"===l?s[s.length-1]:p+(null==l?1.5:l)*v;n.push([d,c,f,p,g]);for(var h=0;h<s.length;h++){var b=s[h];if(b<d||b>g){var x=[u,b];"vertical"===r.layout&&x.reverse(),a.push(x)}}}return{boxData:n,outliers:a,axisData:i}}}.call(t,r,t,e),!(void 0!==o&&(e.exports=o))},function(e,t,r){var o;o=function(e){return function(e,t){var r=(e.length-1)*t+1,o=Math.floor(r),n=+e[o-1],a=r-o;return a?n+a*(e[o]-n):n}}.call(t,r,t,e),!(void 0!==o&&(e.exports=o))}])});
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
echarts线是一种可视化工具,用于展示数据的分布情况和异常值。箱线通过展示一组数据的四分位数(Q1、Q2、Q3)、上下限、中位数以及异常值来帮助我们了解数据的分布和离群点的存在。为了绘制echarts线,可以使用echarts库中的dataTool.prepareBoxplotData()方法对数据进行预处理,得到箱线所需的各种参数值,例如四分位数、上下限、异常值等。然后,可以分别绘制箱线和异常值的散点来呈现数据的分布情况。在绘制箱线时,可以根据需要调用prepareBoxplotData()方法返回的参数值来设置相关参数,例如箱线的颜色、线条样式等。通过观察箱线,我们可以直观地了解数据的集中趋势、离散程度以及是否存在异常值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Echarts数据可视化 第4章 Echarts可视化 4.9 箱线](https://blog.csdn.net/weixin_44226181/article/details/129632176)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Django+Python+Echarts对招聘数据进行可视化分析](https://download.csdn.net/download/wchg21131/88222605)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值