python计算面积折线图_Python交互图表可视化Bokeh:4. 折线图| 面积图

折线图与面积图

① 单线图、多线图

② 面积图、堆叠面积图

1. 折线图--单线图

importnumpy as npimportpandas as pdimportmatplotlib.pyplot as plt%matplotlib inlineimportwarnings

warnings.filterwarnings('ignore')#不发出警告

from bokeh.io importoutput_notebook

output_notebook()#导入notebook绘图模块

from bokeh.plotting importfigure,show#导入图表绘制、图标展示模块

source = ColumnDataSource(data = df) 这里df中index、columns都必须有名称字段

p.line(x='index',y='value',source = source, line_width=1, line_alpha = 0.8, line_color = 'black',line_dash = [10,4])

# 绘制折线图

p.circle(x='index',y='value',source = source, size = 2,color = 'red',alpha = 0.8) # 绘制折点

#1、折线图 - 单线图

from bokeh.models importColumnDataSource#导入ColumnDataSource模块#将数据存储为ColumnDataSource对象#参考文档:http://bokeh.pydata.org/en/latest/docs/user_guide/data.html#可以将dict、Dataframe、group对象转化为ColumnDataSource对象

df= pd.DataFrame({'value':np.random.randn(100).cumsum()})#创建数据

df.index.name = 'index'source= ColumnDataSource(data =df)#转化为ColumnDataSource对象#这里注意了,index和columns都必须有名称字段

p= figure(plot_width=600, plot_height=400)

p.line(x='index',y='value',source = source, #设置x,y值, source → 数据源

line_width=1, line_alpha = 0.8, line_color = 'black',line_dash = [10,4]) #线型基本设置#绘制折线图

p.circle(x='index',y='value',source =source,

size= 2,color = 'red',alpha = 0.8)#绘制折点

show(p)

df.head()

 

可以将dict、Dataframe、group对象转化为ColumnDataSource对象

dic = {'index':df.index.tolist(), 'value':df['value'].tolist()} #一般把它先变成字典的格式

source = ColumnDataSource(data=dic)

#不转换为字典也可以,把index提取出来df.index.name = 'a' --->>> source = ColumnDataSource(data = df)

from bokeh.models importColumnDataSource#导入ColumnDataSource模块#将数据存储为ColumnDataSource对象#参考文档:http://bokeh.pydata.org/en/latest/docs/user_guide/data.html#可以将dict、Dataframe、group对象转化为ColumnDataSource对象

dic= {'index':df.index.tolist(), 'value':df['value'].tolist()} #一般把它先变成字典的格式

source = ColumnDataSource(data=dic)print(source)

p= figure(plot_width=600, plot_height=400)

p.line(x='index',y='value',source = source, #设置x,y值, source → 数据源

line_width=1, line_alpha = 0.8, line_color = 'black',line_dash = [10,4]) #线型基本设置#绘制折线图

show(p)

df.index.name = 'a' #不转换为字典也可以,把index提取出来

source = ColumnDataSource(data =df)

p= figure(plot_width=600, plot_height=400)

p.line(x='a',y='value',source = source, #设置x,y值, source → 数据源

line_width=1, line_alpha = 0.8, line_color = 'black',line_dash = [10,4]) #线型基本设置#绘制折线图

show(p)

df.index.name = 'a'source= ColumnDataSource(data =df)

p=figure()

p.line(x='a',y='value',source = source) #设置x,y值, source → 数据源

show(p)

2. 折线图--多线图

① multi_line

p.multi_line([df.index, df.index], [df['A'], df['B']], color=["firebrick", "navy"], alpha=[0.8, 0.6], line_width=[2,1],)

#2、折线图 - 多线图#① multi_line

df= pd.DataFrame({'A':np.random.randn(100).cumsum(),"B":np.random.randn(100).cumsum()})#创建数据

p= figure(plot_width=600, plot_height=400)

p.multi_line([df.index, df.index],#第一条线的横坐标和第二条线的横坐标

[df['A'], df['B']], #注意x,y值的设置 → [x1,x2,x3,..], [y1,y2,y3,...] 第一条线的Y值和第二条线的Y值

color=["firebrick", "navy"], #可同时设置 → color= "firebrick";也可以统一弄成一个颜色。

alpha=[0.8, 0.6], #可同时设置 → alpha = 0.6

line_width=[2,1], #可同时设置 → line_width = 2

)#绘制多段线#这里由于需要输入具体值,故直接用dataframe,或者dict即可

show(p)

② 多个line

p.line(x, 10**(x**2), legend="y=10^(x^2)",line_color="coral", line_dash="dashed", line_width=2)

#2、折线图 - 多线图#② 多个line

x= np.linspace(0.1, 5, 100)#创建x值

p= figure(title="log axis example", y_axis_type="log",y_range=(0.001, 10**22))#这里设置对数坐标轴

p.line(x, np.sqrt(x), legend="y=sqrt(x)",

line_color="tomato", line_dash="dotdash")#line1

p.line(x, x, legend="y=x")

p.circle(x, x, legend="y=x")#line2,折线图+散点图

p.line(x, x**2, legend="y=x**2")

p.circle(x, x**2, legend="y=x**2",fill_color=None, line_color="olivedrab")#line3

p.line(x,10**x, legend="y=10^x",line_color="gold", line_width=2)#line4

p.line(x, x**x, legend="y=x^x",line_dash="dotted", line_color="indigo", line_width=2)#line5

p.line(x,10**(x**2), legend="y=10^(x^2)",line_color="coral", line_dash="dashed", line_width=2)#line6

p.legend.location= "top_left"p.xaxis.axis_label= 'Domain'p.yaxis.axis_label= 'Values (log scale)'

#设置图例及label

show(p)

3. 面积图

#3、面积图 - 单维度面积图

s= pd.Series(np.random.randn(100).cumsum())

s.iloc[0]=0

s.iloc[-1] =0#创建数据#注意设定起始值和终点值为最低点

p = figure(plot_width=600, plot_height=400)

p.patch(s.index, s.values,#设置x,y值

line_width=1, line_alpha = 0.8, line_color = 'black',line_dash = [10,4], #线型基本设置

fill_color = 'black',fill_alpha = 0.2)#绘制面积图#.patch将会把所有点连接成一个闭合面

show(p)

p.circle(s.index, s.values,size = 5,color = 'red',alpha = 0.8)#绘制折点

#3、面积图 - 面积堆叠图

from bokeh.palettes importbrewer#导入brewer模块

N= 20cats= 10 #分类

rng = np.random.RandomState(1)

df= pd.DataFrame(rng.randint(10, 100, size=(N, cats))).add_prefix('y')#创建数据,shape为(20,10)

df_top = df.cumsum(axis=1) #每一个堆叠面积图的最高点

df_bottom = df_top.shift(axis=1).fillna({'y0': 0})[::-1] #每一个堆叠面积图的最低点,并反向

df_stack = pd.concat([df_bottom, df_top], ignore_index=True) #数据合并,每一组数据都是一个可以围合成一个面的散点集合#得到堆叠面积数据#print(df.head())#print(df_top.tail())#print(df_bottom.head())#df_stack

colors= brewer['Spectral'][df_stack.shape[1]] #根据变量数拆分颜色

x = np.hstack((df.index[::-1], df.index)) #得到围合顺序的index,这里由于一列是20个元素,所以连接成面需要40个点

print(x)

p= figure(x_range=(0, N-1), y_range=(0, 700))

p.patches([x]* df_stack.shape[1], #得到10组index

[df_stack[c].values for c in df_stack], #c为df_stack的列名,这里得到10组对应的valyes

color=colors, alpha=0.8, line_color=None) #设置其他参数

show(p)

[19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 0 1 2 3 4

5 6 7 8 9 10 11 12 13 14 15 16 17 18 19]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/245182.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

上海j计算机一级分值,计算机一级考试内容及分值

计算机一级考试内容有哪些,各题型分值是多少,以下是小编整理的计算机一级考试相关内容,供您参考与阅读。计算机一级考试内容及分值软件环境:Windows 7 操作系统,WPS Office 2012 办公软件。并在指定时间内,完成下列各项操作:(1) 选择题(计算机…

python 多个列表合并_Python对两个有序列表进行合并和排序的例子

Python对两个有序列表进行合并和排序的例子 这篇文章主要介绍了Python对两个有序列表进行合并和排序的例子,最终代码经过不断优化,小编非常满意,需要的朋友可以参考下 假设有2个有序列表l1、l2,如何效率比较高的将2个list合并并保持有序状态,这里默认排序…

启动之后自己关闭_电脑一开都是广告,请问怎么永久关闭?

电脑一开机,主屏广告、右下角弹窗广告蹭蹭蹭的弹个不停,相信很多人都有这样的困扰,尤其是在公共电脑上,广告多的要命。你是否有这样的经历,上学的时候,教室前面的用来讲课的电脑,在老师用PPT授课…

中等职业计算机等级考试,中等职业学校计算机等级考试题库(含答案):EXCEL

中等职业学校计算机等级考试题库(含答案)三 EXCEL20031某工作簿已设置了"打开"与"修改"两种密码,如果只知道其"打开"密码,那么______。A可打开该工作簿,也可以修改,但是不能在原文件夹下用原文件名…

python在统计专业的应用_Python统计学一数据的概括性度量详解

一、数据的概括性度量 1、统计学概括: 统计学是应用数学的一个分支,主要通过利用概率论建立数学模型,收集所观察系统的数据,进行量化的分析、总结,并进而进行推断和预测,为相关决策提供依据和参考。统计学主…

5错误怎么办_“选择不对,一生白费”:如果选错了,该怎么办?记住这两句话...

上帝把1、2、3、4、5、6、7、8、9、0十个数字摆出来,让面前10个人去取,并说道:“一人只能取一个。”人们争先恐后地拥上去,把9、8、7、6、5、4、3都抢走了。取到2和1的人,都说自己运气不好,得到的很少很少。…

北京大学灵异事件计算机房,北大 清华高校 发生的真实恐怖灵异事件

北京大学我有一高中同学b,大学在交大上的,有段时间没联系了,偶然的机会在街上遇到他,当时我被他吓了一跳,只见他脸色发青,眼窝深陷,一问之下,他神情紧张地告诉我:他遇到鬼…

python中 是什么运算符_Python 运算符

Python 运算符 什么是运算符? 本章节主要说明Python的运算符。举个简单的例子4 5 9。 例子中,4和5被称为操作数,""号为运算符。 Python语言支持以下类型的运算符: 算术运算符 比较(关系)运算符 赋值运算符 …

下取整函数的含义_Excel数值取整的7种方式

原标题:Excel数值取整的7种方式上期帮主原创:《高手会这样制作图表~》(在Excel数据处理过程中,数值取整比较常见,且针对不同的要求我们需要采用不同的取整函数来解决。那今天帮主就和大家分享数值取整的7种方式,大家收…

软件测试面试选择判断提,软件测试面试常考判断题

1.软件测试的目的是尽可能多的找出软件的缺陷。( Y)2.负载测试是验证要检验的系统的能力最高能达到什么程度。(N )3.测试人员要坚持原则,缺陷未修复完坚决不予通过。(N)4.自动化测试能比手工测试发现更多的缺陷(N)5. 错误猜测法基于这样一种假设,以前犯过…

python苹果电脑如何下载_python for Mac|python Mac版V2.7.10下载(暂未上线)_预约_飞翔下载...

pythonfor mac是一种即译式的,互动的,面向对象的编程语言,它包含了模组式的操作,异常处理,动态资料形态,十分高层次的动态资料结构,以及类别的使用。如果因为网络原因,去 Python 官网…

idea pom依赖失败_IDEA中Maven依赖下载失败的完美解决方案

使用IDEA进行Maven项目开发时,时不时会遇到pom.xml报错的情况,其中很大概率是因为Maven依赖的jar包下载失败,找来找去也没有找到是什么问题,困扰了很多程序猿,这里给出IDEA中Maven依赖下载失败解决方案,给大…

南京师范大学874计算机答案,2017年南京师范大学电气与自动化工程学院874电路考研题库...

一、计算题1. 计算如图所示电路的输入电阻图【答案】在端口间加电压在该作用下产生电流则解方程得则输入电阻为2. 列写图(a )所示电路矩阵形式的节点方程(用相量)。图【答案】该电路的有向图如图(b )所示。故可写出节点——支路关联矩阵A 和支路阻抗矩阵…

mysql 设置字段自动增长值_mysql命令行脚本

命令行连接在工作中主要使用命令操作方式,要求熟练编写打开终端,运行命令mysql -uroot -p回车后输入密码,当前设置的密码为mysql连接成功后如下图退出登录quit 和 exit或ctrld登录成功后,输入如下命令查看效果查看版本&#xff1a…

ie8不发送ajax,IE8用ajax访问不能每次都刷新的问题

AJAX简介AJAX Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。AJAX 不是新的编程语言,而是一种使用现有标准的新方法。AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。IE8用ajax访问不能每次都刷新的问题介…

graphic方法重写 unity_Unity Shader 深度值重建世界坐标

根据深度重建世界坐标证明世界坐标重建正确的方法首先,得先找到一种证明反推回世界空间位置正确的方法。这里,我在相机前摆放几个物体,尽量使之在世界坐标下的位置小于1,方便判定颜色如下图:然后将几个物体的shader换成…

python显示表格_在Python中获取Excel表格的数量

How get number of sheet in below python example? file self.excel_file.decode(base64) excel_fileobj TemporaryFile(wb) excel_fileobj.write(file) excel_fileobj.seek(0) workbook openpyxl.load_workbook(excel_fileobj, data_onlyTrue) sheet_number ??? sheet…

asp网站本地测试服务器,小旋风asp服务器,asp本地环境调试必备

学习asp,要在本地搭建一个asp服务器调试环境吧,那么必不可少的要找asp本地调试环境软件,超级小旋风AspWebServer是一个不错的选择。超级小旋风AspWebServer系统基于NetBox开发,可以跟IIS媲美的服务器。小旋风asp服务器 该软件是由…

基于sklearn的朴素贝叶斯_Sklearn参数详解—贝叶斯

在开始学习具体的贝叶斯参数前,你可以先看看:朴素贝叶斯详解​mp.weixin.qq.com朴素贝叶斯一共有三种方法,分别是高斯朴素贝叶斯、多项式分布贝叶斯、伯努利朴素贝叶斯,在介绍不同方法的具体参数前,我们先看看这三种方…

快速傅里叶变换python_【原创】OpenCV-Python系列之傅里叶变换(三十八)

OpenCV-Python系列之傅里叶变换 傅里叶变换 我们生活在时间的世界中,早上7:00起来吃早饭,8:00去挤地铁,9:00开始上班。。。以时间为参照就是时域分析。 但是在频域中一切都是静止的!可能有些人无法理解,我建议大家看看…