Python交互图表可视化Bokeh:1. 可视交互化原理| 基本设置
Bokeh
pandas和matplotlib就可以直接出分析的图表了,最基本的出图方式。是面向数据分析过程中出图的工具;Seaborn相比matplotlib封装了一些对数据的组合和识别的功能;用Seaborn出一些针对seaborn的图表是很快的,比如说分布图、热图、分类分布图等。如果用matplotlib需要先group by先分组再出图;
Seaborn在出图的方式上,除了图表的可视化好看,还多了出图的公用性的东西; 关联数据用get去做,空间数据用echart、powmart去做。
什么是Bokeh
基于web端的python数据可视化工具包,可交互()
matplotlib和seaborn都是面向过程的,在数据分析过程中可以呈现;Bokeh是在最后的结果呈现,可做动图,可只打开一张表,也可以做仪表盘的排版,可做图表的联动。

matplotlib是基于numpy和pandas做图表可视化工具包,而seaborn又是基于matplotlib做的
绘图空间基本设置
① 创建绘图空间
② 输出方式
③ 绘图figure基本设置 输出:jupyter notebook / spyder等非notebook空间 参考官方文档:http://bokeh.pydata.org/en/latest/docs/user_guide/styling.html#text-properties
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
% matplotlib inline import warnings
warnings.filterwarnings('ignore')
# 不发出警告
# 在notebook中创建绘图空间 from bokeh.plotting import figure,show
# 导入图表绘制、图标展示模块 from bokeh.io import output_notebook
# 导入notebook绘图模块 output_notebook()
# notebook绘图命令 p = figure(plot_width=400, plot_height=400) # 创建图表,设置宽度、高度
p.circle([1, 2, 3, 4, 5], [6, 7, 2, 4, 5], size=20, color="navy", alpha=0.5)
# 创建一个圆形散点图 show(p)
# 绘图

# 在spyder等非notebook中创建绘图空间 from bokeh.plotting import figure,show,output_file
# 导入图表绘制、图标展示模块
# output_file → 非notebook中创建绘图空间 import os
# os.chdir('C:/Users/Hjx/Desktop/')
os.chdir('C:/Users/Administrator/Desktop')
# 创建工作目录
output_file("line.html")
# notebook绘图命令,创建html文件
# 运行后会弹出html窗口
p = figure(plot_width=400, plot_height=400) # 创建图表,设置宽度、高度
p.circle([1, 2, 3, 4, 5], [6, 7, 2, 4, 5], size=20, color="blue", alpha=0.5)
# 创建一个圆形散点图 show(p)
# 绘图
会弹出一个HTML的页面进行展示:(文件也会存储在创建的目录里边)
1. 图表绘制工具 figure()
p = figure(plot_width = 600, plot_height = 400, tools = 'pan,wheel_zoom,box_zoom,save,reset,help', toolbar_location='above',
x_axis_label = 'A', y_axis_label = 'B',x_range = [-3,3], y_range = [-3,3], title="测试图表" )
p.circle() 绘制散点图
# 创建图表工具
# figure()
df = pd.DataFrame(np.random.randn(100, 2), columns = ['A', 'B'])
p = figure(plot_width = 600, plot_height = 400, # 图表宽度、高度
tools = 'pan,wheel_zoom,box_zoom,save,reset,help', # 设置工具栏,默认全部显示
toolbar_location='above', # 工具栏位置:"above","below","left","right"
x_axis_label = 'A', y_axis_label = 'B', # X,Y轴label
x_range = [-3,3], y_range = [-3,3], # X,Y轴范围
title="测试图表" # 设置图表title
)
# figure创建图表,设置基本参数
# tool参考文档:https://bokeh.pydata.org/en/latest/docs/user_guide/tools.html p.title.text_color = "red"
p.title.text_font = "times"
p.title.text_font_style = "italic"
p.title.background_fill_color = "black"
# 设置标题:颜色、字体、风格、背景颜色 p.circle(df['A'], df['B'], size = 20, alpha = 0.5) # 创建散点图 # 这里.circle()是figure的一个绘图方法
show(p)

颜色设置
# 颜色设置 p = figure(plot_width=600, plot_height=400)
# 创建绘图空间 p.circle(df.index, df['A'], color = 'green', size=10, alpha=0.5)
p.circle(df.index, df['B'], color = '#FF0000', size=10, alpha=0.5) #这两个散点图会在一块一张图上,如果想分开就p1,p2
show(p)
# 颜色设置
# ① 147个CSS颜色,参考网址:http://www.colors.commutercreative.com/grid/
# ② RGB颜色值,参考网址:https://coolors.co/87f1ff-c0f5fa-bd8b9c-af125a-582b11

图表边框线参数设置
p.outline_line_width = 7 # 边框线宽
p.outline_line_alpha = 0.3 # 边框线透明度
p.outline_line_color = "navy" # 边框线颜色
p.outline_line_dash = [6, 4]
# 图表边框线参数设置 p = figure(plot_width=600, plot_height=400)
p.circle(df.index, df['A'], color = 'green', size=10, alpha=0.5)
p.circle(df.index, df['B'], color = '#FF0000', size=10, alpha=0.5)
# 绘制散点图 p.outline_line_width = 7 # 边框线宽
p.outline_line_alpha = 0.3 # 边框线透明度
p.outline_line_color = "navy" # 边框线颜色
p.outline_line_dash = [6, 4]
# 设置图表边框 show(p)

绘图空间背景
p.background_fill_color = "beige" # 绘图空间背景颜色
p.background_fill_alpha = 0.5 # 绘图空间背景透明度
# 设置绘图空间背景 p = figure(plot_width=600, plot_height=400)
p.circle(df.index, df['A'], color = 'green', size=10, alpha=0.5)
p.circle(df.index, df['B'], color = '#FF0000', size=10, alpha=0.5)
# 绘制散点图 p.background_fill_color = "beige" # 绘图空间背景颜色
p.background_fill_alpha = 0.5 # 绘图空间背景透明度
# 背景设置参数 show(p)

外边界背景
p.border_fill_color = "whitesmoke" # 外边界背景颜色
p.border_fill_alpha = 0.5 #透明度
p.min_border_left = 80 # 外边界背景 - 左边宽度
p.min_border_right = 80 # 外边界背景 - 右边宽度
p.min_border_top = 10 # 外边界背景 - 上宽度
p.min_border_bottom = 10
# 设置外边界背景 p = figure(plot_width=600, plot_height=400)
p.circle(df.index, df['A'], color = 'green', size=10, alpha=0.5)
p.circle(df.index, df['B'], color = '#FF0000', size=10, alpha=0.5)
# 绘制散点图 p.border_fill_color = "whitesmoke" # 外边界背景颜色
p.border_fill_alpha = 0.5 #透明度
p.min_border_left = 80 # 外边界背景 - 左边宽度
p.min_border_right = 80 # 外边界背景 - 右边宽度
p.min_border_top = 10 # 外边界背景 - 上宽度
p.min_border_bottom = 10 # 外边界背景 - 下宽度 show(p)

轴线(X Y轴)设置
# Axes - 轴线设置
# 轴线标签、轴线线宽、轴线颜色
# 字体颜色、字体角度 p = figure(plot_width=400, plot_height=400)
p.circle([1,2,3,4,5], [2,5,8,2,7], size=10)
# 绘制图表 p.xaxis.axis_label = "Temp"
p.xaxis.axis_line_width = 3
p.xaxis.axis_line_color = "red"
p.xaxis.axis_line_dash = [6, 4] #虚线 6线4个格子
# 设置x轴线:标签、线宽、轴线颜色 p.yaxis.axis_label = "Pressure"
p.yaxis.major_label_text_color = "orange"
p.yaxis.major_label_orientation = "vertical"
# 设置y轴线:标签、字体颜色、字体角度 p.axis.minor_tick_in = 20 # 刻度往绘图区域内延伸长度;设置成负的就是往外边延伸了。
p.axis.minor_tick_out = 3 # 刻度往绘图区域外延伸长度
# 设置刻度 p.xaxis.bounds = (2, 4)
# 设置轴线范围 show(p)

轴线标签设置
# Axes - 轴线设置
# 标签设置 p = figure(plot_width=400, plot_height=400)
p.circle([1,2,3,4,5], [2,5,8,2,7], size=10) p.xaxis.axis_label = "Lot Number"
p.xaxis.axis_label_text_color = "#aa6666"
p.xaxis.axis_label_standoff = 30 #偏移距离
# 设置标签名称、字体颜色、偏移距离 p.yaxis.axis_label = "Bin Count"
p.yaxis.axis_label_text_font_style = "italic" #字体风格
# 设置标签名称、字体 show(p)

Grid格网设置 -- 线型
# Grid - 格网设置
# 线型设置 p = figure(plot_width=600, plot_height=400)
p.circle(df.index, df['A'], color = 'green', size=10, alpha=0.5)
p.circle(df.index, df['B'], color = '#FF0000', size=10, alpha=0.5)
# 绘制散点图 p.xgrid.grid_line_color = 'red'
# 颜色设置,None时则不显示 p.ygrid.grid_line_alpha = 0.8
p.ygrid.grid_line_dash = [6, 4]
# 设置透明度,虚线设置
# dash → 通过设置间隔来做虚线 p.xgrid.minor_grid_line_color = 'navy'
p.xgrid.minor_grid_line_alpha = 0.1
# minor_line → 设置次轴线 show(p)

格网颜色填充
p.ygrid.band_fill_alpha = 0.1
p.ygrid.band_fill_color = "navy"
# Grid - 格网设置
# 颜色填充 p = figure(plot_width=600, plot_height=400)
p.circle(df.index, df['A'], color = 'green', size=10, alpha=0.5)
p.circle(df.index, df['B'], color = '#FF0000', size=10, alpha=0.5)
# 绘制散点图 p.xgrid.grid_line_color = None
# 设置颜色为空 p.ygrid.band_fill_alpha = 0.1
p.ygrid.band_fill_color = "navy"
# 设置颜色填充,及透明度 #p.grid.bounds = (-1, 1)
# 设置填充边界 show(p)

Legend图例的设置
p.line(x, y, legend="sin(x)")
p.legend.location = "bottom_left" 位置、
p.legend.orientation = "vertical"排列方向 默认
p.legend.label_text_font = "times"
p.legend.label_text_font_style = "italic" # 斜体
p.legend.label_text_color = "navy"
p.legend.label_text_font_size = '12pt'
# 设置图例:字体、风格、颜色、字体大小 p.legend.border_line_width = 3
p.legend.border_line_color = "navy"
p.legend.border_line_alpha = 0.5
# 设置图例外边线:宽度、颜色、透明度 p.legend.background_fill_color = "gray"
p.legend.background_fill_alpha = 0.2
# 设置图例背景:颜色、透明度
# Legend - 图例设置
# 设置方法 → 在绘图时设置图例名称 + 设置图例位置 p = figure(plot_width=600, plot_height=400)
# 创建图表 x = np.linspace(0, 4*np.pi, 100)
y = np.sin(x)
# 设置x,y p.circle(x, y, legend="sin(x)")
p.line(x, y, legend="sin(x)")
# 绘制line1,设置图例名称 p.line(x, 2*y, legend="2*sin(x)",line_dash=[4, 4], line_color="orange", line_width=2)
# 绘制line2,设置图例名称 p.square(x, 3*y, legend="3*sin(x)", fill_color=None, line_color="green")
p.line(x, 3*y, legend="3*sin(x)", line_color="green")
# 绘制line3,设置图例名称 p.legend.location = "bottom_left"
# 设置图例位置:"top_left"、"top_center"、"top_right" (the default)、"center_right"、"bottom_right"、"bottom_center"
# "bottom_left"、"center_left"、"center" p.legend.orientation = "vertical"
# 设置图例排列方向:"vertical" (默认)or "horizontal" p.legend.label_text_font = "times"
p.legend.label_text_font_style = "italic" # 斜体
p.legend.label_text_color = "navy"
p.legend.label_text_font_size = '12pt'
# 设置图例:字体、风格、颜色、字体大小 p.legend.border_line_width = 3
p.legend.border_line_color = "navy"
p.legend.border_line_alpha = 0.5
# 设置图例外边线:宽度、颜色、透明度 p.legend.background_fill_color = "gray"
p.legend.background_fill_alpha = 0.2
# 设置图例背景:颜色、透明度 show(p)

总结一下:
Line Properties → 线设置
Fill Properties → 填充设置
Text Properties → 字体设置
1、Line Properties → 线设置
(1)line_color,设置颜色
(2)line_width,设置宽度
(3)line_alpha,设置透明度
(4)line_join,设置连接点样式:'miter' miter_join,'round' round_join,'bevel' bevel_join
(5)line_cap,设置线端口样式,'butt' butt_cap,'round' round_cap,'square' square_cap
(6)line_dash,设置线条样式,'solid','dashed','dotted','dotdash','dashdot',或者整型数组方式(例如[6,4])
2、Fill Properties → 填充设置
(1)fill_color,设置填充颜色
(2)fill_alpha,设置填充透明度
3、Text Properties → 字体设置
(1)text_font,字体
(2)text_font_size,字体大小,单位为pt或者em( '12pt', '1.5em')
(3)text_font_style,字体风格,'normal' normal text,'italic' italic text,'bold' bold text
(4)text_color,字体颜色
(5)text_alpha,字体透明度
(6)text_align,字体水平方向位置,'left', 'right', 'center'
(7)text_baseline,字体垂直方向位置,'top','middle','bottom','alphabetic','hanging'
4、可见性
p.xaxis.visible = False
p.xgrid.visible = False
基本参数中都含有.visible参数,设置是否可见
Python交互图表可视化Bokeh:1. 可视交互化原理| 基本设置的更多相关文章
- Python交互图表可视化Bokeh:7. 工具栏
ToolBar工具栏设置 ① 位置设置② 移动.放大缩小.存储.刷新③ 选择④ 提示框.十字线 1. 位置设置 import numpy as np import pandas as pd impor ...
- Python交互图表可视化Bokeh:5 柱状图| 堆叠图| 直方图
柱状图/堆叠图/直方图 ① 单系列柱状图② 多系列柱状图③ 堆叠图④ 直方图 1.单系列柱状图 import numpy as np import pandas as pd import matplo ...
- Python交互图表可视化Bokeh:6. 轴线| 浮动| 多图表
绘图表达进阶操作 ① 轴线设置② 浮动设置③ 多图表设置 1. 轴线标签设置 设置字符串 import numpy as np import pandas as pd import matplotli ...
- Python交互图表可视化Bokeh:4. 折线图| 面积图
折线图与面积图 ① 单线图.多线图② 面积图.堆叠面积图 1. 折线图--单线图 import numpy as np import pandas as pd import matplotlib.py ...
- Python交互图表可视化Bokeh:3. 散点图
散点图 ① 基本散点图绘制② 散点图颜色.大小设置方法③ 不同符号的散点图 1. 基本散点图绘制 import numpy as np import pandas as pd import matpl ...
- Python交互图表可视化Bokeh:2. 辅助参数
图表辅助参数设置 辅助标注.注释.矢量箭头 参考官方文档:https://bokeh.pydata.org/en/latest/docs/user_guide/annotations.html#col ...
- 利用R语言进行交互数据可视化(转)
上周在中国R语言大会北京会场上,给大家分享了如何利用R语言交互数据可视化.现场同学对这块内容颇有兴趣,故今天把一些常用的交互可视化的R包搬出来与大家分享. rCharts包 说起R语言的交互包,第一个 ...
- 利用R语言制作出漂亮的交互数据可视化
利用R语言制作出漂亮的交互数据可视化 利用R语言也可以制作出漂亮的交互数据可视化,下面和大家分享一些常用的交互可视化的R包. rCharts包 说起R语言的交互包,第一个想到的应该就是rCharts包 ...
- (数据科学学习手札106)Python+Dash快速web应用开发——回调交互篇(下)
本文示例代码已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 这是我的系列教程Python+Dash快速web ...
随机推荐
- 使用layui框架做分页
第一步引用两个文件: <link href="layui-v2.2.5/layui-v2.2.5/layui/css/layui.css" rel="stylesh ...
- jQuery页面滚动底部加载数据
$(window).scroll(function () { var scrollTop = $(this).scrollTop(); var scrollHeight = ...
- 小白6步搞定vue脚手架创建项目
1.安装node及npm node -v (测试node是否安装成功)npm -v(测试npm是否安装成功) 2.安装cnpm npm install -g cnpm --registry=http: ...
- 关于STM32 __IO 的变量定义
这个_IO 是指静态 这个 _IO 是指静态 volatile uint32_t 是指32位的无符号整形变量uint32_t 是指32位的无符号整形变量: 搞stm32这么久了,经常看到stm32里面 ...
- SQL语句的行列转换
[一]行转列 1,查询原始的数据 /***这次练习的主题,行转列,列转行***/select * from Scores 2,得到姓名,通过group by select Student as '姓名 ...
- 信息摘要算法之六:HKDF算法分析与实现
HKDF是一种特定的键衍生函数(KDF),即初始键控材料的功能,KDF从其中派生出一个或多个密码强大的密钥.在此我们想要描述的是基于HMAC的HKDF. 1.HKDF概述 密钥派生函数(KDF)是密码 ...
- nodejs之koa-router与koa-body搭配使用
简介 koa需要搭配中间件来做接口更方便,使用Koa-body & Koa-router 使用 koa2 创建接口,处理post请求 const koa=require("koa&q ...
- JavaScript(JS)之简单介绍
一.JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件中).后将其改名ScriptEase.(客户端执行的语言) N ...
- 关系代数和sql语句对应关系
关系代数运算符 对应sql语句 聚合操作 ∪ (UNION)并 ∩ (INTERSECTION)交 - (DIFFERENCE)差 × (Cartesian PRODUCT)笛卡尔积 ...
- bzoj3276磁力 两种要求下的最大值:分块or线段树+拓扑
进阶指南上的做法是分块的.. 但是线段树搞起来也挺快,将磁石按照距离排序,建立线段树,结点维护区间质量最小值的下标 进行拓扑,每次在可行的范围内在线段树中找到质量最小的下标取出,取出后再将线段树对应的 ...