版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
项目三:—PyEcharts应用目录CONTENTS任务3.3 设置系列配置项任务3.4 绘制基础图表任务3.5 绘制直角坐标系图形任务3.6 绘制树形图及地理图形项目概述学习目标任务3.1 PyEchats入门任务3.2 设置全局配置项思考与练习091项目概述继Matplotlib之后,本项目介绍PyEcharts绘图。与Matplotlib相比,PyEcharts可实现炫酷的绘图效果,同时具有独有的特点。PyEcharts在基本图表、地图、3D图表、层叠多图、动画效果、交互控件等方面都非常优秀,是功能全面的绘图包,学习和使用PyEcharts是非常有必要的。项目概述在PyEcharts出现之后Python的可视化工作方便了很多,由于是开源项目,所以图表种类资源丰富、使用方便,而且图表制作美观、运行稳定。本项目融合PyEcharts基础知识与综合绘图为一体,着重介绍PyEcharts常用配置项和图表的应用,同时可结合综合应用对所学内容进行练习,以便熟练掌握本项目内容。本项目所有任务均使用JupyterNotebook进行开发。PyEcharts安装与入门1PyEcharts配置项简介与应用2PyEcharts常用图表绘制3项目概述2学习目标
学习目标通过本项目的学习,掌握PyEcharts全局配置和系统配置项使用方法及数据类型,熟练调用修改配置项参数达到想要实现的功能和目的,以及PyEcharts的图表绘制方法、图片API和直角坐标图、树形图、地理图表。让学生了解PyEcharts绘图软件与Echarts本质上的异同,具备基本的程序逻辑素养,持续更新知识储备。3PyEchats入门Echarts是一个由百度开源的数据可视化javascript库,凭借其良好的交互性,精巧的图表设计,得到了众多开发者的认可。Python是一门富有表达力的语言,很适合用于数据处理。当数据分析遇上数据可视化时,PyEcharts诞生了。PyEcharts作为Python数据可视化库的热门,本任务对PyEcharts的特点、安装、配置项等进行讲解与实践,初步了解PyEcharts的使用方法,掌握PyEcharts部分全局配置项的目的。任务描述本项目以实际数据为基础,绘制可视化图表,切身体会PyEcharts可视化工具的作用,拓宽大数据可视化知识广度,利用PyEcharts实现精美图表,激发学习兴趣与积极性。通过学习本任务内容,了解Echarts与PyEcharts的特点、PyEcharts安装和主题应用、PyEcharts快速入门,掌握PyEcharts全局配置项类别、掌握画图动画配置项、初始化配置项、工具箱配置项、工具箱工具配置项等,并依据练习题将所学知识巩固应用。任务描述Echarts&PyEchartsEcharts是由百度开源的数据可视化库,内部图例丰富,其图表具有良好的交互性,具有非常完善的中文文档,广受用户喜爱。PyEcharts是一个用于生成Echarts图表的Python库,Echarts是一个JavaScript库,而PyEcharts是连接Python与Echarts的桥梁,通过渲染机制,输出一个包含JavaScript代码的HTML文件,这一点在使用Pycharm时可以清晰地观察到。Pyecharts包含了基本图表、地图、3D图、多子图、动画五个功能,Pyecharts作为Python可视化浪潮的产物,有着简洁的API设计,而且还包含了30多种常见的图表函数可供调用。010203知识与技能——Echarts&PyEcharts简介知识与技能——Echarts&PyEcharts简介在代码编写方面PyEcharts支持主流的JupyterNotebook、JupyterLab和PyCharm等编程环境,还可轻松集成至Flask,Django等主流Web框架,最重要的是它拥有多达400+地图文件以及原生的百度地图,为地理数据可视化提供强有力的支持。Matplotlib擅长绘制2D图表,更擅长在研究领域进行数据分析与可视化,具有稳定和使用方法简单的特点,同时对图表的定制化需求也非常完善。PyEcharts更擅长结合Web进行可视化大屏展示,使用非常方便,并且可与主流Web控件结合,形成交互式可视化大屏,在地图领域尤为擅长。动画配置项顾名思义就是控制图表绘图过程的动画效果,PyEcharts提供了该配置项的八种可以调用的函数,具体内容如右:初始动画的缓动效果,animation_easing:Union[str]="cubicOut"。04初始动画的时长,默认值为1000,支持回调函数,可以通过每个数据返回不同的delay时间实现更戏剧的初始动画效果,animation_duration:Union[Numeric,JSFunc]=1000。03是否开启动画的阈值,当单个系列显示的图形数量大于这个阈值时会关闭动画。默认2000,animation_threshold:Numeric=2000。02是否开启动画,默认为True开启,animation:bool=True。01知识与技能——AnimationOpts:Echarts动画配置项顾名思义就是控制图表绘图过程的动画效果,PyEcharts提供了该配置项的八种可以调用的函数,具体内容如右:数据更新动画的延迟,默认值为0,支持回调函数,可以通过每个数据返回不同的delay时间实现更戏剧的更新动画效果,animation_delay_update:Union[Numeric,JSFunc]=0。08数据更新动画的缓动效果,animation_easing_update:Union[Numeric]="cubicOut"。07数据更新动画的时长,默认值为300,支持回调函数,可以通过每个数据返回不同的delay时间实现更戏剧的更新动画效果,animation_duration_update:Union[Numeric,JSFunc]=300。06初始动画的延迟,默认值为0支持回调函数,可以通过每个数据返回不同的delay时间实现更戏剧的初始动画效果,animation_delay:Union[Numeric,JSFunc]=0。05知识与技能——AnimationOpts:Echarts知识与技能——AnimationOpts:Echarts其中回调函数需要特别了解一下,回调函数就是一个被作为参数传递的函数。在C语言中,回调函数只能使用函数指针实现,在C++、Python、ECMAScript等更现代的编程语言中还可以使用仿函数或匿名函数,回调函数因为可以把调用者与被调用者分开,所以调用者不关心谁是被调用者。它只需知道存在一个具有特定原型和限制条件的被调用函数。简而言之,回调函数就是允许用户把需要调用的函数的指针作为参数传递给一个函数,以便该函数在处理相似事件的时候可以灵活地使用不同的方法。回调函数在实际中有许多作用,假设有这样一种情况:需要编写一个库,它提供了某些排序算法的实现(如冒泡排序、快速排序、shell排序、shake排序等等),为了能让库更加通用,不想在函数中嵌入排序逻辑,而让使用者来实现相应的逻辑;或者,能让库可用于多种数据类型(int、float、string),此时,可以使用函数指针,并进行回调。初始化配置项意味着这是你画图的开始,一切画图的准备工作就要由初始化配置项中的参数帮你完成,在Pyecharts中初始化配置项函数包含九种,分别是:渲染风格,可选"canvas","svg"renderer:str=RenderType.CANVAS。04图表ID,图表唯一标识,用于在多图表时区分,chart_id:Optional[str]=None,03图表画布高度,css长度单位,height:str="500px"。02图表画布宽度,css长度单位,width:str="900px"。01知识与技能——InitOpts:初始化配置项初始化配置项意味着这是你画图的开始,一切画图的准备工作就要由初始化配置项中的参数帮你完成,在Pyecharts中初始化配置项函数包含九种,分别是:远程jshost,如不设置默认为/assets/"js_host:str=""。08图表背景颜色bg_color:Optional[str]=None。07图表主题theme:str="white"。06网页标题page_title:str="Awesome-pyecharts"。05知识与技能——InitOpts:初始化配置项09画图动画初始化配置animation_opts:Union[AnimationOpts,dict]=AnimationOpts()。
之前讲到的画图动画配置项包含在初始化配置项当中,只是因为初始化配置项涉及多个函数,所以单独拿出来强调一下,初始化配置项不同于全局配置项和系列配置项,其函数都有默认的值,如果不引用函数更改那么程序会自动取默认值帮你绘制图表,如图所示便是取默认值时图表的样子。知识与技能——InitOpts:初始化配置项工具箱配置项是调整美化图标的一个工具,toolboxOpt类里包含了6个函数共同控制工具栏组件的位置和大小,具体函数代码如下:知识与技能——ToolboxOpts:工具箱配置项is_show:bool=True,工具栏组件显示开关。orient:str="horizontal",工具栏icon的布局朝向,可选:'horizontal','vertical'。pos_left:str="80%",工具栏组件离容器左侧的距离,left的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比,也可以是'left','center','right',如果left的值为'left','center','right',组件会根据相应的位置自动对齐。工具箱配置项是调整美化图标的一个工具,toolboxOpt类里包含了6个函数共同控制工具栏组件的位置和大小,具体函数代码如下:知识与技能——ToolboxOpts:工具箱配置项pos_right:Optional[str]=None,工具栏组件离容器右侧的距离,right的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比。pos_top:Optional[str]=None,工具栏组件离容器上侧的距离,top的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比,也可以是'top','middle','bottom',如果top的值为'top','middle','bottom',组件会根据相应的位置自动对齐。pos_bottom:Optional[str]=None,工具栏组件离容器下侧的距离,bottom的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比。第一步:安装PyEcharts,在CMD窗口输入以下命令:pipinstallpyecharts任务实施——PyEcharts的安装任务实施——PyEcharts的安装第二步:如何查看使用的Pyecharts版本,首先进入python环境,然后输入:importpyechartsprint(pyecharts.__version__)任务实施——Pyecharts快速入门
PyEcharts中可以绘制的图有很多,这里先总体了解一下它的使用风格、调用方式,有宏观的理解后再具体学习图形的绘制。#载入包frompyecharts.chartsimportBarimportsqlalchemyassql第一步:导包任务实施——Pyecharts快速入门第二步:导入数据库数据这一步导入该操作后续会用到的数据,因此后续仅展示操作内容不会重新导入数据。#(1)连接数据库engine=sql.create_engine('mysql+pymysql://root:root@localhost:3306/dataproject')#数据库mysql名称
sql1='''select*fromquxianrenshu'''#数据库mysql中表的名称
df=pd.read_sql(sql1,engine)#(2)赋值将要输出数据到变量x_data=list(df["year"].values)
y_data1=list(df["Numberofprefectureleveldivisions"].values)
y_data1=[int(i)foriiny_data1]
y_data2=list(df["Numberofmunicipaldistricts"].values)
print(type(y_data2[0]))
y_data2=[int(i)foriiny_data2]
print(type(y_data2))*小提示*这里需要注意的是,因为PyEcharts的图表仅接收list列表格式的数据,list中的值应为int,而直接从表格中赋值的数据虽然也是list格式,但是其中的值为,如果不进行循环转化后续运行的时候,PyEcharts图表就没有办法读取到值,则会输出一张空表。数据格式如图所示。任务实施——Pyecharts快速入门任务实施——Pyecharts快速入门第三步:绘制图形程序代码如下,输出效果如图所示。#输入柱状图函数bar=Bar()#传入x,y轴参数
bar.add_xaxis(x_data)
bar.add_yaxis(“市数”,y_data1)
bar.add_yaxis(“乡镇数",y_data2)
bar.render()任务实施——PyEcharts画图动画配置项和初始化配置项示例代码如下:#导包frompyecharts.chartsimportBar#编写IniOpts参数变量并输入数据c=(
Bar(init_opts=opts.InitOpts(
animation_opts=opts.AnimationOpts(animation=False)#这个是开关动画的选项,当数据量大的时候可以选择关闭
)).add_xaxis(x_data)
.add_yaxis("地级市数",y_data1)
.add_yaxis("县级市数",y_data2))#输出结果c.render_notebook()任务实施——PyEcharts画图动画配置项和初始化配置项运行结果如图所示。任务实施——PyEcharts画图动画配置项和初始化配置项InitOpts可以配置诸如图像宽度、高度、图表主题,背景颜色,进行一个操作实例,实例中引用前期编写的变量x_data,y_data1,y_data2,在x轴引用x_data将数值填充进x轴,然后在y轴引用y_data1,y_data2填充数值,完成图表内的数据填写。其中需要注意的是initopts初始化类的应用方法和格式,width,height,theme,bg_color等参数均可以在上图参数表中寻找自行添加。知识拓展
任务实施——工具箱配置项和工具箱工具配置项(1)ToolboxOpts调用示例:#导入包frompyecharts.chartsimportBar#编写IniOpts参数变量并输入数据c=(
Bar(init_opts=opts.InitOpts(
animation_opts=opts.AnimationOpts(animation=False)#这个是开关动画的选项,当数据量大的时候可以选择关闭
)).add_xaxis(x_data)
.add_yaxis(“数”,y_data1)
.add_yaxis(“乡镇数",y_data2)
#全局配置项中工具箱配置项的应用.set_global_opts(
title_opts=opts.TitleOpts(
title="2012年~2021年国家行政区县划分数量",
title_textstyle_opts=opts.TextStyleOpts(font_size=22),
pos_right="center"),#全局配置项中图例配置项的应用
legend_opts=opts.LegendOpts(
type_='scroll',
selected_mode='double',
pos_left='center',
pos_top='95%',
orient='horizontal',
),
toolbox_opts=opts.ToolboxOpts()
)
)#输出结果c.render_notebook()任务实施——工具箱配置项和工具箱工具配置项输出效果如图所示。任务实施——工具箱配置项和工具箱工具配置项(2)布局测试示例:#导入包frompyecharts.chartsimportBar#编写IniOpts参数变量并输入数据c=(
Bar(init_opts=opts.InitOpts(
)).add_xaxis(x_data)
.add_yaxis(“市数”,y_data1)
.add_yaxis(“乡镇数",y_data2)#全局配置项中标题配置项(22号字体居中显示).set_global_opts(
title_opts=opts.TitleOpts(
title="2012年~2021年国家行政区县划分数量",
title_textstyle_opts=opts.TextStyleOpts(font_size=22),
pos_right="center"),#全局配置项中图例配置项
legend_opts=opts.LegendOpts(
type_='scroll',
selected_mode='double',
pos_left='center',
pos_top='95%',
orient='horizontal',
),#全局配置项中工具箱配置项
toolbox_opts=opts.ToolboxOpts(
orient='vertical',
pos_left='90%',
pos_top='10%')
)
)#输出结果c.render_notebook()任务实施——工具箱配置项和工具箱工具配置项输出效果如图所示。任务实施——工具箱配置项和工具箱工具配置项(3)工具箱配置项ToolBoxFeatureOpts示例:#导入包frompyecharts.chartsimportBar#编写IniOpts参数变量c=(
Bar(init_opts=opts.InitOpts(
)).add_xaxis(x_data)
.add_yaxis(“市数”,y_data1)
.add_yaxis(“乡镇数",y_data2)#全局配置项中标题配置项.set_global_opts(
title_opts=opts.TitleOpts(
title="2012年~2021年国家行政区县划分数量",
title_textstyle_opts=opts.TextStyleOpts(font_size=22),
pos_right="center"),#全局配置项中图例配置项
legend_opts=opts.LegendOpts(
type_='scroll',
selected_mode='double',
pos_left='center',
pos_top='95%',
orient='horizontal',
),#全局配置项中工具箱配置项(均为默认值)
toolbox_opts=opts.ToolboxOpts(
feature=opts.ToolBoxFeatureOpts(
save_as_image=opts.ToolBoxFeatureSaveAsImageOpts(),#图片保存项
restore=opts.ToolBoxFeatureRestoreOpts(),#配置项还原
data_view=opts.ToolBoxFeatureDataViewOpts(),#数据视图工具
data_zoom=opts.ToolBoxFeatureDataZoomOpts(),#数据区域缩放
magic_type=opts.ToolBoxFeatureMagicTypeOpts(),#动态类型切换。
brush=opts.ToolBoxFeatureBrushOpts()#选框组件的控制按钮
)
)
)
)#输出图表c.render_notebook()任务实施——工具箱配置项和工具箱工具配置项输出效果如图所示。通过本任务的学习,了解PyEcharts的发展过程,Echarts的发展带动Python可视化进程加快,从而出现了PyEcharts。学习PyEcharts初始化配置项内容,如动画配置项、工具箱配置项、工具箱数据视图工具、工具箱保存图片配置项、工具箱还原配置项等。本任务的重点是学习和PyEcharts发展过程以及PyEcharts初始化配置项内容的代码实例,可以通过反复练习、课外学习相关知识等方式来掌握。基于本任务的成果,完成PyEcharts可视化配置项的部分内容,为后续学习可视化图表打下了基础。任务总结4设置全局配置项任务描述什么是全局配置项?PyEcharts并没有一个具体的概念解释,而是给了一张图,如图所示。可以看出全局配置项里包括标题配置项、图例配置项和视觉映射配置项等组件。全局配置项中具体的组件是作用在全局的,即作用在整个图形中的。在官方文件中一共介绍了22个组件,大多有异曲同工之处。
本任务通过常用的数据实例,将这些配置项具体应用到可视化图表当中,展示如何设置全局配置项。通过学习本任务内容,了解PyEcharts全局配置项的功能、参数和特点,熟悉PyEcharts全局配置项中工具箱区域配置项、标题配置项、区域缩放配置项、图例配置项、视觉映射配置项、提示框配置项、极坐标配置项等,并通过练习题将所学知识巩固应用。任务描述知识与技能——TitleOpts标题配置项标题配置项顾名思义是给图表命名一个标题,标题分为主次标题可以为一个链接,标题配置项类包含了11个函数具体如下:title:Optional[str]=None,#主标题文本,支持使用\n换行。title_link:Optional[str]=None,#主标题文本,支持使用\n换行。title_target:Optional[str]=None,主标题跳转链接方式,默认值是:blank。其中可选参数:'self','blank','self'当前窗口打开;'blank'新窗口打开
知识与技能——TitleOpts标题配置项subtitle:Optional[str]=None,副标题文本,支持使用\n换行。subtitle_link:Optional[str]=None,副标题跳转URL链接。subtitle_target:Optional[str]=None,副标题跳转链接方式,默认值是:blank,可选参数:'self','blank','self'当前窗口打开;'blank'新窗口打开。知识与技能——TitleOpts标题配置项pos_left:Optional[str]=None,title组件离容器左侧的距离,left的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比,也可以是'left','center','right',如果left的值为'left','center','right',组件会根据相应的位置自动对齐。pos_right:Optional[str]=None,title组件离容器右侧的距离。right的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比。pos_top:Optional[str]=None,title组件离容器上侧的距离,top的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比,也可以是'top','middle','bottom',如果top的值为'top','middle','bottom',组件会根据相应的位置自动对齐。知识与技能——TitleOpts标题配置项pos_bottom:Optional[str]=None,title组件离容器下侧的距离,bottom的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比。padding:Union[Sequence,Numeric]=5,标题内边距,单位px,默认各方向内边距为5,接受数组分别设定上右下左边距,设置内边距为5padding:5,设置上下的内边距为5,左右的内边距为10padding:[5,10],分别设置四个方向的内边距padding:[5,//上10,//右5,//下10,//左#]。知识与技能——LegendOpts:图例配置项1.type_:Optional[str]=None,图例的类型。可选值:'plain':普通图例。缺省就是普通图例,'scroll':可滚动翻页的图例。当图例数量较多时可以使用。2.selected_mode:Union[str,bool,None]=None,图例选择的模式,控制是否可以通过点击图例改变系列的显示状态。默认开启图例选择,可以设成false关闭,除此之外也可以设成'single'或者'multiple'使用单选或者多选模式。3.is_show:bool=True,是否显示图例组件。图例配置项是指选定的数据的标识,图例配置项类中包含了15个函数,具体如下:知识与技能——LegendOpts:图例配置项4.pos_left:Union[str,Numeric,None]=None,图例组件离容器左侧的距离,left的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比,也可以是'left','center','right',如果left的值为'left','center','right',组件会根据相应的位置自动对齐。5.pos_right:Union[str,Numeric,None]=None,图例组件离容器右侧的距离,right的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比。6.pos_top:Union[str,Numeric,None]=None,图例组件离容器上侧的距离,top的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比,也可以是'top','middle','bottom',如果top的值为'top','middle','bottom',组件会根据相应的位置自动对齐。知识与技能——LegendOpts:图例配置项7.pos_bottom:Union[str,Numeric,None]=None,图例组件离容器下侧的距离,bottom的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比。8.orient:Optional[str]=None,图例列表的布局朝向。可选:'horizontal','vertical'。9.align:Optional[str]=None,图例标记和文本的对齐。默认自动(auto),根据组件的位置和orient决定,当组件的left值为'right'以及纵向布局(orient为'vertical')的时候为右对齐,即为'right',可选参数:`auto`,`left`,`right`。知识与技能——LegendOpts:图例配置项10.padding:int=5,图例内边距,单位px,默认各方向内边距为5。11.item_gap:int=10,图例每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔,默认间隔为10。12.item_width:int=25,图例标记的图形宽度。默认宽度为25。知识与技能——LegendOpts:图例配置项13.item_height:int=14,图例标记的图形高度。默认高度为14。14.inactive_color:Optional[str]=None,图例关闭时的颜色。默认是#ccc。15.legend_icon:Optional[str]=None,图例项的icon,ECharts提供的标记类型包括'circle','rect','roundRect','triangle','diamond','pin','arrow','none',可以通过'image://url'设置为图片,其中URL为图片的链接,或者dataURI,可以通过'path://'将图标设置为任意的矢量路径。知识与技能——VisualMapOpts:视觉映射配置项1.is_show:bool=True,是否显示视觉映射配置。2.type_:str="color",映射过渡类型,可选,"color","size"。3.min_:Union[int,float]=0,指定visualMapPiecewise组件的最小值。4.max_:Union[int,float]=100,指定visualMapPiecewise组件的最大值。视觉映射配置项是全局配置项中包含函数最多的,因为它掌控了可以观察到图标的所有可视项的参数,该类一共包含了27个函数,分别如下:知识与技能——VisualMapOpts:视觉映射配置项5.range_text:Union[list,tuple]=None,两端的文本,如['High','Low']。6.range_color:Union[Sequence[str]]=None,visualMap组件过渡颜色。7.range_size:Union[Sequence[int]]=None,visualMap组件过渡symbol大小8.range_opacity:Optional[Numeric]=None,visualMap图元以及其附属物(如文字标签)的透明度。知识与技能——VisualMapOpts:视觉映射配置项9.orient:str="vertical",如何放置visualMap组件,水平('horizontal')或者竖直('vertical')。10.pos_left:Optional[str]=None,visualMap组件离容器左侧的距离,left的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比,也可以是'left','center','right',如果left的值为'left','center','right',组件会根据相应的位置自动对齐。11.pos_right:Optional[str]=None,visualMap组件离容器右侧的距离,right的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比。知识与技能——VisualMapOpts:视觉映射配置项12.pos_top:Optional[str]=None,visualMap组件离容器上侧的距离,top的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比,也可以是'top','middle','bottom',如果top的值为'top','middle','bottom',组件会根据相应的位置自动对齐。13.pos_bottom:Optional[str]=None,visualMap组件离容器下侧的距离,bottom的值可以是像20这样的具体像素值,可以是像'20%'这样相对于容器高宽的百分比。14.split_number:int=5,对于连续型数据,自动平均切分成几段。默认为5段。连续数据的范围需要max和min来指定。
知识与技能——VisualMapOpts:视觉映射配置项16.dimension:Optional[Numeric]=None,组件映射维度。17.is_calculable:bool=True,是否显示拖拽用的手柄(手柄能拖拽调整选中范围)。18.is_piecewise:bool=False,是否为分段型。19.is_inverse:bool=False,是否反转visualMap组件。20.precision:Optional[int]=None,数据展示的小数精度,连续型数据平均分段,精度根据数据自动适应,连续型数据自定义分段或离散数据根据类别分段模式,精度默认为0(没有小数)。知识与技能——VisualMapOpts:视觉映射配置项21.pieces:Optional[Sequence]=None,自定义的每一段的范围,以及每一段的文字,以及每一段的特别的样式。22.out_of_range:Optional[Sequence]=None,定义在选中范围外的视觉元素。(用户可以和visualMap组件交互,用鼠标或触摸选择范围)可选的视觉元素有:symbol:图元的图形类别,symbolSize:图元的大小,color:图元的颜色,colorAlpha:图元的颜色的透明度,opacity:图元以及其附属物(如文字标签)的透明度,colorLightness:颜色的明暗度,参见HSL,colorSaturation:颜色的饱和度,参见HSL,colorHue:颜色的色调,参见HSL。知识与技能——VisualMapOpts:视觉映射配置项23.item_width:int=0,图形的宽度,即长条的宽度。24.item_height:int=0,图形的高度,即长条的高度。25.background_color:Optional[str]=None,visualMap组件的背景色。26.border_color:Optional[str]=None,visualMap组件的边框颜色。27.border_width:int=0,visualMap边框线宽,单位px。
知识与技能——TooltipOpts:提示框配置项1.is_show:bool=True,是否显示提示框组件,包括提示框浮层和axisPointer。2.trigger:str="item",触发类型。可选,'item':数据项图形触发,主要在散点图,饼图等无数目轴的图表中使用,'axis':坐标轴触发,主要在柱状图,折线图等会儿使用类目轴的图表中使用,'none':什么都不触发。指示框配置项使我们将鼠标移动到图上之后显示数据的框架指示框,该类包含了13种函数,具体如下,值得强调的是formatter函数中支持回调函数,应该注重回调函数的格式:知识与技能——TooltipOpts:提示框配置项3.trigger_on:str="mousemove|click",提示框触发的条件,可选,'mousemove':鼠标移动时触发,'click':鼠标点击时触发,'mousemove|click':同时鼠标移动和点击时触发,'none':不在'mousemove'或'click'时触发。
4.axis_pointer_type:str="line",指示器类型。可选,'line':直线指示器,'shadow':阴影指示器,'none':无指示器,'cross':十字准星指示器。其实是种简写,表示启用两个正交的轴的axisPointer。知识与技能——TooltipOpts:提示框配置项5.is_show_content:bool=True,是否显示提示框浮层,默认显示,只需tooltip触发事件或显示axisPointer而不需要显示内容时可配置该项为false。6.is_always_show_content:bool=False,是否永远显示提示框内容,默认情况下在移出可触发提示框区域后一定时间后隐藏,设置为true可以保证一直显示提示框内容。知识与技能——TooltipOpts:提示框配置项7.show_delay:Numeric=0,浮层显示的延迟,单位为ms,默认没有延迟,也不建议设置。8.hide_delay:Numeric=100,浮层隐藏的延迟,单位为ms,在alwaysShowContent为true的时候无效。9.position:Union[str,Sequence,JSFunc]=None,提示框浮层的位置,默认不设置时位置会跟随鼠标的位置,1、通过数组配置:绝对位置,相对于容器左侧10px,上侧10px===>position:[10,10],相对位置,放置在容器正中间===>position:['50%','50%'],2、通过回调函数配置,3、固定参数配置:'inside','top','left','right','bottom'。知识与技能——TooltipOpts:提示框配置项10.formatter:Optional[str]=None,标签内容格式器,支持字符串模板和回调函数两种形式,字符串模板与回调函数返回的字符串均支持用\n换行,字符串模板模板变量有:{a}:系列名,{b}:数据名,{c}:数据值,{@xxx}:数据中台为'xxx'的维度的值,如{@product}表示名为'product'`的维度的值,{@[n]}:数据中维度n的值,如{@[3]}`表示维度3的值,从0开始计数,示例:formatter:'{b}:{@score}'回调函数,回调函数格式:(params:Object|Array)=>string,参数params是formatter需要的单个数据集。知识与技能——TooltipOpts:提示框配置项11.background_color:Optional[str]=None,提示框浮层的背景颜色。12.border_color:Optional[str]=None,提示框浮层的边框颜色。13.border_width:Numeric=0,提示框浮层的边框宽。知识与技能——PolarOpts:极坐标系配置1.center:Optional[Sequence]=None,极坐标系的中心(圆心)坐标,数组的第一项是横坐标,第二项是纵坐标,支持设置成百分比,设置成百分比时第一项是相对于容器宽度,第二项是相对于容器高度。2.radius:Optional[Union[Sequence,str]]=None,极坐标系的半径。可以为如下类型,umber:直接指定外半径值,string:例如,'20%',表示外半径为可视区尺寸(容器高宽中较小一项)的20%长度,Array.<number|string>数组的第一项是内半径,第二项是外半径。每一项遵从上述numberstring的描述。3.tooltip_opts:TooltipOpts=None,本坐标系特定的tooltip设定。参考`global_options.TooltipOpts`。任务实施——标题配置项#载入包frompyecharts.chartsimportBarfrompyechartsimportoptionsasoptsimportsqlalchemyassqlimportpandasaspd第一步:导入相关包第二步:导入数据库数据#连接数据库engine=sql.create_engine('mysql+pymysql://root:root@localhost:3306/dataproject')#数据库mysql名称sql1='''select*fromjiuye'''#数据库mysql中表的名称df=pd.read_sql(sql1,engine)#赋值将要输出数据到变量x_data=list(df["时间"].values)y_data1=list(df["第一产业就业人员(万人)"].values)y_data2=list(df["第二产业就业人员(万人)"].values)y_data3=list(df["第三产业就业人员(万人)"].values)任务实施——标题配置项第三步:编写IniOpts参数变量和应用方法#全局配置项中标题配置项
.set_global_opts(title_opts=opts.TitleOpts(title="2012年~2021年三次产业就业人员数量",subtitle='近十年',title_link='/easyquery.htm?cn=C01',#主标题跳转链接title_target='blank',title_textstyle_opts=opts.TextStyleOpts(font_size=22),subtitle_textstyle_opts=opts.TextStyleOpts(color='#f987a2',font_size=22),pos_right="center"),
#全局配置项中图例配置项legend_opts=opts.LegendOpts(type_='scroll',selected_mode='double',pos_left='center',pos_top='95%',orient='horizontal')))#输出图表c.render_notebook()任务实施——标题配置项输出效果如图所示。任务实施——图例配置项#载入包frompyecharts.chartsimportBarfrompyechartsimportoptionsasoptsimportsqlalchemyassqlimportpandasaspd第一步:导入相关包第二步:导入数据库数据#连接数据库engine=sql.create_engine('mysql+pymysql://root:root@localhost:3306/dataproject')#数据库mysql名称sql1='''select*fromjiuye'''#数据库mysql中表的名称df=pd.read_sql(sql1,engine)#赋值将要输出数据到变量x_data=list(df["时间"].values)y_data1=list(df["第一产业就业人员(万人)"].values)y_data2=list(df["第二产业就业人员(万人)"].values)y_data3=list(df["第三产业就业人员(万人)"].values)任务实施——图例配置项第三步:设置参数和应用方法c=(
Bar(init_opts=opts.InitOpts())
.add_xaxis(x_data)
.add_yaxis("第一产业就业",y_data1)
.add_yaxis("第二产业就业",y_data2)
.add_yaxis("第三产业就业",y_data3).set_global_opts(
title_opts=opts.TitleOpts(
title="2012年~2021年三次产业就业人员数量",
title_textstyle_opts=opts.TextStyleOpts(font_size=22),
pos_right="center"),
legend_opts=opts.LegendOpts(
legend_opts=opts.LegendOpts(
legend_icon='图片链接(自行添加)’,
item_height=5,
item_width=5,
item_gap=20,
type_='scroll',
selected_mode='double',
pos_left='center',
pos_top='95%',
orient='horizontal',
)))c.render_notebook()任务实施——图例配置项程序运行效果如下:任务实施——图例配置项*知识拓展*(1)图例基本概念相关参数参数意义参数+意义默认is_show是否显示图例组件True/FalseTruetype_图例的类型'plain':普通图例<br>'scroll':可滚动翻页的图例,当图例数量较多时可以使用。'plain'selected_mode图例选择的模式'single':单选
<br>'multiple':多选模式'multiple'orient布局朝向'horizontal';横排列<br>'vertical':竖排列Nonepos_left离容器左侧的距离['0%','100%']Nonepos_right离容器右侧的距离['0%','100%']Nonepos_top离容器上侧的距离['0%','100%']Nonepos_bottom离容器下侧的距离['0%','100%']None任务实施——图例配置项*知识拓展*(2)图例细调概念相关参数参数意义参数+意义默认align图文对齐方式left子右图左<br>'right'子左图右autopadding图例内边距int5item_gap图例每项之间距离int10item_width图形宽度int25item_height图形高度int14inactive_color图例关闭时的颜色str#ccctextstyle_opts图例组件字体样式options.TextStyleOpts(参数)Nonelegend_icon图片'image://url'设置为图片
<br>'path://'设置为图片None任务实施——视觉映射配置项#载入包frompyecharts.chartsimportBarfrompyechartsimportoptionsasoptsimportsqlalchemyassqlimportpandasaspd第一步:导入相关包第二步:导入数据库数据#连接数据库engine=sql.create_engine('mysql+pymysql://root:root@localhost:3306/dataproject')#数据库mysql名称sql1='''select*fromjiuye'''#数据库mysql中表的名称df=pd.read_sql(sql1,engine)#赋值将要输出数据到变量x_data=list(df["时间"].values)y_data1=list(df["第一产业就业人员(万人)"].values)y_data2=list(df["第二产业就业人员(万人)"].values)y_data3=list(df["第三产业就业人员(万人)"].values)任务实施——视觉映射配置项c=(
Bar(init_opts=opts.InitOpts())
.add_xaxis(x_data)
.add_yaxis("第一产业就业",y_data1)
.add_yaxis("第二产业就业",y_data2)
.add_yaxis("第三产业就业",y_data3).set_global_opts(#全局配置项中视觉映射配置项visualmap_opts=opts.VisualMapOpts(
max_=40000,
pos_bottom="10%"),#全局配置项中标题配置项
title_opts=opts.TitleOpts(
title="2012年~2021年三次产业就业人员数量",
title_textstyle_opts=opts.TextStyleOpts(font_size=22),
pos_right="center"),#全局配置项中图例配置项,请参考之前代码
))c.render_notebook()第三步:设置参数并输出图像任务实施——视觉映射配置项程序运行结果如下图所示:任务实施——视觉映射配置项*知识拓展*(1)基本参数参数意义参数+意义默认is_show是否显示视觉映射配置True,FalseTrue,type_映射过渡类型"color":颜色显示<br>"size":光影显示"color"min_组件的最小值int0max_组件的最大值int100任务实施——视觉映射配置项*知识拓展*(2)组件相关参数参数意义参数+意义默认range_text两端的文本['High','Low']Nonerange_color组件过渡颜色strNonerange_size组件过渡symbol大小intNonerange_opacity图元以及其附属物(如文字标签)的透明度0%-%100Nonebackground_color组件的背景色。strNoneborder_color组件的边框颜色strNoneborder_width边框线宽int0textstyle_opts文字样式配置项TextStyleOpts()None任务实施——视觉映射配置项*知识拓展*(3)组件位置相关参数参数意义参数+意义默认orient水平或竖直'horizontal':水平<br>'vertical':竖直"vertical"pos_left组件离容器左侧[0%-100%]Nonepos_right组件离容器右侧[0%-100%]Nonepos_top组件离容器上侧[0%-100%]Nonepos_bottom组件离容器下侧[0%-100%]None任务实施——视觉映射配置项*知识拓展*(4)分段类型相关参数参数意义参数+意义默认series_index选取哪个系列的数据intNonesplit_number平均切分成几段int5is_piecewise是否为分段型True/FalseFalseis_inverse是否反转组件True/FalseFalse任务实施——提示框配置项c=(
Bar(init_opts=opts.InitOpts())
.add_xaxis(x_data)
.add_yaxis("第一产业就业",y_data1)
.add_yaxis("第二产业就业",y_data2)
.add_yaxis("第三产业就业",y_data3).set_global_opts(#全局配置项中提示框配置项tooltip_opts=opts.TooltipOpts(),#全局配置项中标题配置项
title_opts=opts.TitleOpts(
title="2012年~2021年三次产业就业人员数量",
title_textstyle_opts=opts.TextStyleOpts(font_size=22),
pos_right="center"),#全局配置项中图例配置项,请参考之前任务代码
)))c.render_notebook()
示例重要程序如下:任务实施——提示框配置项TooltipOpts除了上述简单的输出还有其他的写法,在Tooltip_opts=opts.TooltipOpts()的TooltipOpts()中添加下列方法即可完成。(1)框架使用,程序代码如下.set_global_opts(#全局配置项中提示框配置项tooltip_opts=opts.TooltipOpts(
trigger='axis',
trigger_on='mousemove',
axis_pointer_type='cross'),#全局配置项中标题配置项
title_opts=opts.TitleOpts(
title="2012年~2021年三次产业就业人员数量",
title_textstyle_opts=opts.TextStyleOpts(font_size=22),
pos_right="center"),#全局配置项中图例配置项,请参考之前任务代码
))c.render_notebook()任务实施——提示框配置项程序运行结果如下任务实施——提示框配置项颜色设置,程序代码如下,输出结果如图所示。.set_global_opts(#全局配置项中提示框配置项(边框背景颜色)tooltip_opts=opts.TooltipOpts(
trigger='axis',
border_color="#69d6c1",
background_color="#f987a2",
border_width=2,
textstyle_opts=opts.TextStyleOpts(color='#2521E5')),#全局配置项中标题配置项
title_opts=opts.TitleOpts(
title="2012年~2021年三次产业就业人员数量",
title_textstyle_opts=opts.TextStyleOpts(font_size=22),
pos_right="center"),#全局配置项中图例配置项,请参考之前任务代码
))c.render_notebook()任务实施——提示框配置项程序运行结果如下通过本任务的学习,了解了PyEcharts的全局配置项,如工具箱选框组件配置项、工具箱动态类型切换配置项、工具箱选框组件配置项、工具箱选框组件配置项、标题配置项、区域缩放配置项、图例配置项等。本任务的重点是学习PyEcharts的全局配置项概念,以及PyEcharts的全局配置项内容的代码实例,可通过反复练习、课外学习相关知识等方式来掌握。基于本任务的成果,完成PyEcharts可视化配置项的部分内容,为后续学习可视化图表打下了基础。任务总结5设置系列配置项和全局配置项一样,PyEcharts并没有给系列配置项一个明确的定义。系列配置项通常指可对局部的某一系列参数进行设置的配置项。
这里的局部某一系列,可以是柱状图里某商家对应的柱子;折线图里某一系列数据对应的一条折线;图表里的某部分文字等。为了更好地展现数据,在作图时需要对图表里的某部分做出个性化的修改,此时就是系列配置项大展身手的时候了。任务描述系列配置项里包括图元样式配置项、文字样式配置项和标签式配置项等组件,这些具体的组件是作用在系列的,也即作用在整个图形中。在PyEcharts的官方文档中,系列配置项共包含17个组件,它们大多有异曲同工之处。本任务通过常用的数据实例将这些配置项具体应用到可视化图表当中,学习如何来设置系列配置项。通过学习本任务内容,了解PyEcharts系列配置项的功能、参数和特点,熟悉PyEcharts系列配置项中的图元样式配置项、文字样式配置项、标签配置项等,通过习题将所学知识巩固应用。任务描述知识与技能——ItemStyleOpts:图元样式配置项1.color:Optional[str]=None,图形的颜色,颜色可以使用RGB表示,比如'rgb(128,128,128)',如果想要加上alpha通道表示不透明度,可以使用RGBA,比如'rgba(128,128,128,0.5)',也可以使用十六进制格式,比如'#ccc',除了纯色之外颜色也支持渐变色和纹理填充线性渐变,前四个参数分别是x0,y0,x2,y2,范围从0-1,相当于在图形包围盒中的百分比,如果globalCoord为`true`则该四个值是绝对的像素位置。2.color0:Optional[str]=None,阴线图形的颜色。图元样式配置项主要控制图表内容的颜色透明度边框样式等参数,该类包含了8个函数分别如下:知识与技能——ItemStyleOpts:图元样式配置项3.border_color:Optional[str]=None,图形的描边颜色。支持的颜色格式同color,不支持回调函数。4.border_color0:Optional[str]=None,阴线图形的描边颜色。5.border_width:Optional[Numeric]=None,描边宽度,默认不描边。6.border_type:Optional[str]=None,支持'dashed','dotted'。7.opacity:Optional[Numeric]=None,图形透明度。支持从0到1的数字,为0时不绘制该图形。
8.area_color:Optional[str]=None,区域的颜色。
知识与技
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 《工伤事故管理办法》课件
- 《服装品牌设计策划》课件
- 单位管理制度集合大合集【职工管理篇】
- 单位管理制度集粹汇编【员工管理篇】十篇
- 《学前儿童的注意》课件
- 单位管理制度合并汇编职工管理篇十篇
- 单位管理制度分享合集人力资源管理十篇
- 单位管理制度范文大合集人事管理十篇
- 单位管理制度范例合集【职员管理】
- 单位管理制度呈现大合集【职员管理篇】
- 江苏科技大学高等数学期末考试试卷(含答案)
- 英语介绍家乡省份江西
- 建设工程见证取样管理规范
- 中国成人血脂异常防治指南解读
- 医学专家谈灵芝孢子粉课件
- 弹性力学19年 吴家龙版学习通超星课后章节答案期末考试题库2023年
- 有没有租学位的协议书
- 住宅小区绿化管理规定
- 土建工程定额计价之建筑工程定额
- 2022年7月云南省普通高中学业水平考试物理含答案
- 学校安全工作汇报PPT
评论
0/150
提交评论