目录

概述

1 认识Bokeh

1.1 Bokeh介绍

1.2 安装Bokeh

1.3 范例介绍

2 Bokeh的应用

2.1 Bokeh应用的框架结构

2.2 实时性数据核心原理

3 具体案例

3.1 代码实现

3.2 部署和运行


概述

Bokeh是一个用于创建交互式可视化的Python库,特别适合在Web浏览器中展示。它能够生成各种类型的图表,并且支持高度交互性,如平移、缩放、选择、悬停提示等。以下是一个简单的Bokeh示例,展示如何创建一个带有交互功能的折线图。

1 认识Bokeh

1.1 Bokeh介绍

Bokeh 是一个强大的交互式可视化库,专为现代 Web 浏览器设计。它支持创建高性能、可交互的图表和仪表盘,适用于大规模数据集。

核心优势:

  1. 交互性强:支持平移、缩放、悬停提示、选择等

  2. 输出灵活:生成 HTML 文件、嵌入 Jupyter Notebook 或部署为 Web 应用

  3. 流式数据支持:实时更新图表(如金融数据流)

  4. 多种渲染器:Canvas、SVG、WebGL 支持

1.2 安装Bokeh

官方网站地址:

https://docs.bokeh.org/en/latest/index.html#

打开网站其页面如下,目前其最新版本已经更新至:v3.7.3

该packet对Python要求其版本必须升级至Python 3.10,安装命令源代码:

pip install bokeh

1.3 范例介绍

官网提供了许多冠以Bokeh的使用案例,程序员可参考这些Demo实现自己感兴趣的功能,基础案例如下:

2 Bokeh的应用

2.1 Bokeh应用的框架结构

2.2 实时性数据核心原理

实时数据可视化核心原理,Bokeh 通过 ColumnDataSource 和回调机制实现实时数据更新:

  1. 数据源对象ColumnDataSource 存储可视化数据

  2. 流式更新stream() 方法增量添加新数据

  3. 回调函数:周期性更新数据源

  4. Bokeh 服务器:维护应用状态和处理实时更新

3 具体案例

3.1 代码实现

应用Bokeh模拟传感器实时更新数据的特性 

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# @Time    : 2020/4/9 13:05
# @Author  : ming fei.tang
# @File    : debug tools
# ---------------------
from bokeh.plotting import figure, curdoc
from bokeh.models import ColumnDataSource, Range1d, HoverTool
from bokeh.layouts import column
from bokeh.models.widgets import Div
import random
import datetime
import numpy as np# 创建数据源
source = ColumnDataSource(data={'time': [],'temperature': [],'humidity': []
})# 创建图表
temp_plot = figure(title='温度传感器实时数据',x_axis_type='datetime',width=1000, height=300,tools="pan,wheel_zoom,box_zoom,reset"
)
temp_plot.line('time', 'temperature', source=source, line_width=2, color='red', legend_label="温度(℃)")
temp_plot.y_range = Range1d(15, 35)humidity_plot = figure(title='湿度传感器实时数据',x_axis_type='datetime',width=1000, height=300,x_range=temp_plot.x_range  # 共享X轴范围
)
humidity_plot.line('time', 'humidity', source=source, line_width=2, color='blue', legend_label="湿度(%)")
humidity_plot.y_range = Range1d(0, 100)# 状态面板
stats_div = Div(text="<h3>传感器状态: <span style='color:green'>运行中</span></h3>", width=200)# 模拟数据生成
def generate_sensor_data():current_time = datetime.datetime.now()# 模拟温度(带有小幅波动)base_temp = 25 + 5 * np.sin(current_time.minute / 30 * np.pi)temperature = base_temp + random.uniform(-0.5, 0.5)# 模拟湿度(与温度反向变化)humidity = 50 - 0.8 * (temperature - 25) + random.uniform(-2, 2)return {'time': [current_time],'temperature': [temperature],'humidity': [max(0, min(100, humidity))]  # 限制在0-100范围}# 更新函数
def update():new_data = generate_sensor_data()# 流式更新source.stream(new_data, rollover=300)  # 保留300个最新数据点# 更新状态面板stats_div.text = f"""<div style="background:#f9f9f9; padding:10px; border-radius:5px"><h3>传感器状态: <span style='color:green'>✓ 运行中</span></h3><p>最后更新时间: {datetime.datetime.now().strftime('%H:%M:%S')}</p><p>当前温度: <b>{new_data['temperature'][0]:.1f}℃</b></p><p>当前湿度: <b>{new_data['humidity'][0]:.1f}%</b></p><p>数据点数: {len(source.data['time'])}</p></div>"""# 添加悬停工具
hover = HoverTool(tooltips=[("时间", "@time{%F %T}"),("温度", "@temperature{0.0}℃"),("湿度", "@humidity{0}%")
], formatters={'@time': 'datetime'})temp_plot.add_tools(hover)# 设置布局和更新频率
layout = column(stats_div, temp_plot, humidity_plot)
curdoc().add_root(layout)
curdoc().add_periodic_callback(update, 1000)  # 每秒更新一次
curdoc().title = "实时传感器监控"

3.2 部署和运行

具体方法如下:

部署与运行方法

  1. 保存为 Python 文件xxx.py

  2. 启动 Bokeh 服务器

    bash

    bokeh serve --show xxx.py
  3. 浏览器访问http://localhost:5006/xxx

笔者创建的项目结构如下:

在终端运行该代码,运行方法如下:

在该.py文件所在目录下运行该命令:

bokeh serve --show Bokeh_stud.py

终端上显示如下信息,说明系统已经正常启动:

在浏览器上会显示页面:

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

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

相关文章

Elasticsearch「kNN Retriever」把向量检索装进一条 \_search 管线

1. kNN retriever 是什么&#xff1f; kNN retriever 是 Retriever 框架中的首阶段召回器&#xff0c;负责对一个向量字段做近邻搜索&#xff0c;返回 Top-K 文档。相比早期的 knn 顶级语法&#xff0c;Retriever 让我们能在一个请求里组合多种策略&#xff08;如 RRF/Rescorer…

第四天~在CANFD或CAN2.0的ARXML文件中实现Multiplexor多路复用信号实战

【ARXML专题】-解锁CAN信号超能力:Multiplexor多路复用技术深度解析 "当你的CAN帧需要传输100种信号却只有64字节时,就像试图用行李箱装下一整个衣橱——Multiplexor就是你的真空压缩袋" 信号拥堵时代的救世主 现代豪华汽车中,单个ECU可能需处理500+信号,而传统…

JavaScript 基础入门:从零开始学 JS

一、JavaScript 简介JavaScript&#xff08;简称 JS&#xff09;是一种高级的、解释型的编程语言&#xff0c;由 Netscape 公司的 Brendan Eich 在 1995 年开发&#xff0c;最初命名为 LiveScript&#xff0c;后因与 Java 的合作关系而改名为 JavaScript。作为 Web 开发的三大核…

pytest中使用loguru的问题及解决

引语 上一篇文章,我们向大家推荐了python语言的一个第三方日志库loguru,使用非常简单且功能完备。 但对于我们做自动化测试,经常使用 pytest 框架的小伙伴来说,却有点小问题。就是 Pytest 内建的日志捕获机制是在标准库 logging 的基础上进行优化过的。 这样我们在使用 p…

Qt异步编程:QFuture与QPromise深度解析

在现代GUI应用中&#xff0c;异步操作是保证界面流畅性的关键。本文将深入探讨Qt框架中强大的异步工具——QFuture和QPromise&#xff0c;揭示它们如何简化多线程编程并提升应用性能。 为什么需要QFuture/QPromise&#xff1f; 在Qt开发中&#xff0c;我们经常面临这样的挑战&a…

基于Python的电影评论数据分析系统 Python+Django+Vue.js

本文项目编号 25008 &#xff0c;文末自助获取源码 \color{red}{25008&#xff0c;文末自助获取源码} 25008&#xff0c;文末自助获取源码 目录 一、系统介绍1.1 用户功能1.2 管理员功能 二、系统录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状 六、…

数据结构:在二叉搜索树中插入元素(Insert in a BST)

目录 插入的本质是什么&#xff1f; 如何寻找“合法”的位置&#xff1f;—— 模拟查找过程 递归插入&#xff08;Recursive Insert&#xff09;—— 优雅的实现 代码逐步完善 总结 上一节我们从第一性原理搞清楚了二叉搜索树&#xff08;BST&#xff09;是什么&#xff0…

【论文阅读】美 MBSE 方法发展分析及启示(2024)

文章目录 论文摘要 论文框架 1. MBSE 方法概述 2. 美国防部的 MBSE 方法政策要求 在这里插入图片描述 3. 美军兵种的 MBSE 方法政策要求 4. 启示 5.总结 参考文献 论文摘要 本文梳理了美国防部基于模型的系统工程(MBSE)方法的发展历程,并剖析 其技术原理;跟踪《数字工程战略…

人工智能训练师复习题目实操题1.1.1 - 1.1.5

列出所有的python 库和 apiimport pandas as pd import numpy as np就这两个库pandas 库 - apinumpy 库 - apimatplotlib.pyplot - apipd.read_csv()np.where(condition,x,y)fillna(methodffill,inplaceTrue)methodbfill,pd.read_excel()np返回结果 series 对象 data[A列].valu…

旅游管理实训室:旅游教育实践育人的关键支撑

在中等职业教育旅游服务与管理专业教学中&#xff0c;旅游管理实训室并非简单的教学场所&#xff0c;而是落实专业教学标准、实现 “理实一体化” 育人的核心阵地。它通过模拟真实职业场景、配置专业实训设备、设计实践教学活动&#xff0c;将抽象的专业知识转化为具体的操作技…

http工作流程

HTTP&#xff08;Hypertext Transfer Protocol&#xff0c;超文本传输协议&#xff09;是互联网中客户端与服务器之间传输超文本&#xff08;如HTML、图片、JSON等&#xff09;的核心协议&#xff0c;基于请求-响应模型和TCP/IP协议族工作。其完整工作流程可拆解为以下9个核心步…

正则表达式实用面试题与代码解析专栏

正则表达式是前端表单验证、字符串匹配的核心工具,简洁高效的正则能大幅提升代码性能。本专栏整理了7道高频面试题,包含核心正则表达式、代码实现及关键知识点解析,帮你快速掌握正则实用技巧。 一、正则基础:核心概念与语法 在学习面试题前,先明确几个高频基础语法,这是…

【数据可视化-89】基孔肯雅热病例数据分析与可视化:Python + pyecharts洞察疫情动态

&#x1f9d1; 博主简介&#xff1a;曾任某智慧城市类企业算法总监&#xff0c;目前在美国市场的物流公司从事高级算法工程师一职&#xff0c;深耕人工智能领域&#xff0c;精通python数据挖掘、可视化、机器学习等&#xff0c;发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…

云智智慧停充一体云-allnew全新体验-路内停车源码+路外停车源码+充电桩源码解决方案

采用Java主流的微服务技术栈&#xff0c;基于 Spring Cloud Alibaba 的微服务解决方案进行封装的快速开发平台&#xff0c;包含多种常用开箱即用功能的模块&#xff0c;通用技术组件与服务、微服务治理&#xff0c;具备RBAC功能、网关统一鉴权、Xss防跨站攻击、自动生成前后端代…

利用pypy加速pyxlsbwriter生成xlsb文件

上文介绍了python通过DuckDB和pyxlsbwriter模块生成xlsb文件&#xff0c;因为python是解释执行&#xff0c;它的速度有点慢&#xff0c;pypy是另一种python解释器&#xff0c;它使用即时编译&#xff08;JIT&#xff09;技术来提高执行速度。 因为DuckDB与pypy不兼容&#xff0…

【Java后端】Spring Boot 集成 MyBatis-Plus 全攻略

Spring Boot 集成 MyBatis-Plus 全攻略 1. 为什么选择 MyBatis-Plus 零侵入&#xff1a;在 MyBatis 基础上增强&#xff0c;不影响现有功能。内置 CRUD&#xff1a;无需写 XML/SQL&#xff0c;直接调用 BaseMapper 方法。强大插件&#xff1a;分页插件、性能分析、乐观锁、多租…

LangChain 多任务应用开发

Q: LangChain dify coze是竞品关系 都是AI Agent搭建平台&#xff0c;dify和coze 属于低代码&#xff0c;langChain属于高代码&#xff0c;coze优于dify Q&#xff1a;向量数据库是存储向量&#xff0c;做相似度检索的&#xff0c;可以用faiss milvus chromdb Q&#xff1a;使用…

实用技巧:Oracle中精准查看表占用空间大小

目录实用技巧&#xff1a;Oracle中精准查看表占用空间大小一、为什么需要精准统计表空间占用&#xff1f;二、完整查询SQL&#xff1a;覆盖表、LOB、索引三、SQL语句关键逻辑解析1. 基础表&#xff1a;dba_tables 与 dba_tablespaces2. 子查询1&#xff1a;统计表段空间&#x…

openEuler等Linux系统中如何复制移动硬盘的数据

在 openEuler 系统中,提示 “You should mount volume first” ,意思是需要先挂载移动硬盘的分区才能访问: 安装必要软件(针对特殊文件系统) 如果移动硬盘是 NTFS 等非 Linux 原生支持的文件系统格式,需要安装对应的支持软件,以挂载 NTFS 格式移动硬盘为例,需要安装 …

java如何把字符串数字转换成数字类型

在Java中将字符串数字转换为数字类型有多种方法&#xff0c;以下是详细说明和示例代码&#xff1a; 一、基础转换方法 Integer.parseInt() String str "123"; int num Integer.parseInt(str); // 转换为intDouble.parseDouble() String str "3.14"; dou…