【flask框架搭建服务器demo】Python 使用轻量级 Flask 框架搭建 Web 服务器可视化数据库数据demo

本文适合刚入门flask框架用来熟悉项目的开发人员,关于flask框架的组成概念一些用法请参考下面的文章

https://blog.csdn.net/qq_47452807/article/details/122289200

本文主要给出一个可视化sqlite数据库数据的demo,先展示一下效果:

主要的代码如下

(1)app.py文件

from flask import Flask, jsonify, render_template
import sqlite3# 创建一个Flask应用实例
app = Flask(__name__)# 定义SQLite数据库的路径
DATABASE_PATH = r'E:\qt_data\sensordata.db'# 获取数据库连接的函数
def get_db_connection():# 连接到SQLite数据库conn = sqlite3.connect(DATABASE_PATH)# 将数据库查询结果设置为字典格式,便于通过列名访问数据conn.row_factory = sqlite3.Rowreturn conn# 定义根路由(主页)的处理函数
@app.route('/')
def index():# 渲染index.html模板return render_template('index.html')# 定义/data路由的处理函数,返回JSON格式的传感器数据
@app.route('/data')
def data():# 获取数据库连接conn = get_db_connection()# 创建游标对象,用于执行SQL查询cursor = conn.cursor()# 执行SQL查询,获取最新的20条环境数据记录,按时间戳降序排列cursor.execute("SELECT * FROM env_data ORDER BY timestamp DESC LIMIT 20")# 获取查询结果的所有行rows = cursor.fetchall()# 关闭数据库连接conn.close()# 构建一个字典,将查询结果中的每列数据提取到对应的列表中data = {"timestamp": [row["timestamp"] for row in rows],  # 时间戳"co2": [row["co2"] for row in rows],              # 二氧化碳浓度"ch2o": [row["ch2o"] for row in rows],            # 甲醛浓度"tvoc": [row["tvoc"] for row in rows],            # 总挥发性有机化合物浓度"pm2_5": [row["pm2_5"] for row in rows],          # PM2.5浓度"pm10": [row["pm10"] for row in rows],            # PM10浓度"temp": [row["temp"] for row in rows],            # 温度"hum": [row["hum"] for row in rows],              # 湿度}# 将数据字典转换为JSON格式并返回return jsonify(data)# 主函数,启动Flask应用
if __name__ == '__main__':app.run(debug=True)  # debug模式运行应用,方便开发调试

(2)index.html文件

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Environmental Data Visualization</title><script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
</head>
<body><div style="width: 80%; margin: auto;"><canvas id="lineChart"></canvas></div><script src="{{ url_for('static', filename='js/script.js') }}"></script>
</body>
</html>

(3)script.js文件

// 异步函数fetchData,用于从服务器获取传感器数据
async function fetchData() {// 发送HTTP GET请求到服务器的'/data'路由,并等待响应const response = await fetch('/data');// 将响应转换为JSON格式的数据const data = await response.json();// 返回获取到的数据return data;
}// 函数createChart,用于根据传感器数据创建并初始化折线图
function createChart(data) {// 获取页面中ID为'lineChart'的canvas元素,并获取其2D绘图上下文const ctx = document.getElementById('lineChart').getContext('2d');// 使用Chart.js库创建一个折线图const chart = new Chart(ctx, {type: 'line',  // 图表类型为折线图data: {// 设置X轴的标签为时间戳(数据需要反转以使最新数据在最右侧)labels: data.timestamp.reverse(),// 定义多条数据集,每个数据集代表一种传感器数据datasets: [{label: 'CO2',  // 数据集标签为'CO2'data: data.co2.reverse(),  // 数据为CO2的浓度值(反转顺序)borderColor: 'rgb(255, 99, 132)',  // 设置线条颜色为红色fill: false  // 不填充曲线下方区域},{label: 'CH2O',  // 数据集标签为'CH2O'data: data.ch2o.reverse(),  // 数据为CH2O的浓度值(反转顺序)borderColor: 'rgb(54, 162, 235)',  // 设置线条颜色为蓝色fill: false  // 不填充曲线下方区域},{label: 'TVOC',  // 数据集标签为'TVOC'data: data.tvoc.reverse(),  // 数据为TVOC的浓度值(反转顺序)borderColor: 'rgb(75, 192, 192)',  // 设置线条颜色为青色fill: false  // 不填充曲线下方区域},{label: 'PM2.5',  // 数据集标签为'PM2.5'data: data.pm2_5.reverse(),  // 数据为PM2.5的浓度值(反转顺序)borderColor: 'rgb(153, 102, 255)',  // 设置线条颜色为紫色fill: false  // 不填充曲线下方区域},{label: 'PM10',  // 数据集标签为'PM10'data: data.pm10.reverse(),  // 数据为PM10的浓度值(反转顺序)borderColor: 'rgb(255, 159, 64)',  // 设置线条颜色为橙色fill: false  // 不填充曲线下方区域},{label: 'Temperature',  // 数据集标签为'温度'data: data.temp.reverse(),  // 数据为温度值(反转顺序)borderColor: 'rgb(255, 205, 86)',  // 设置线条颜色为黄色fill: false  // 不填充曲线下方区域},{label: 'Humidity',  // 数据集标签为'湿度'data: data.hum.reverse(),  // 数据为湿度值(反转顺序)borderColor: 'rgb(201, 203, 207)',  // 设置线条颜色为灰色fill: false  // 不填充曲线下方区域}]},options: {// 使图表自适应容器大小responsive: true,scales: {x: {display: true,  // 显示X轴title: {display: true,  // 显示X轴的标题text: 'Timestamp'  // 设置X轴标题为'时间戳'}},y: {display: true,  // 显示Y轴title: {display: true,  // 显示Y轴的标题text: 'Value'  // 设置Y轴标题为'数值'}}}}});// 返回创建的图表对象return chart;
}// 异步函数updateChart,用于更新图表数据
async function updateChart(chart) {// 获取最新的数据const data = await fetchData();// 更新图表的X轴标签(时间戳),并反转顺序chart.data.labels = data.timestamp.reverse();// 更新各个数据集的数据,并反转顺序chart.data.datasets[0].data = data.co2.reverse();chart.data.datasets[1].data = data.ch2o.reverse();chart.data.datasets[2].data = data.tvoc.reverse();chart.data.datasets[3].data = data.pm2_5.reverse();chart.data.datasets[4].data = data.pm10.reverse();chart.data.datasets[5].data = data.temp.reverse();chart.data.datasets[6].data = data.hum.reverse();// 更新图表显示chart.update();
}// 在DOM完全加载后执行的事件监听器函数
document.addEventListener('DOMContentLoaded', async function () {// 获取初始数据const data = await fetchData();// 创建并渲染图表const chart = createChart(data);// 每隔1秒更新一次图表数据setInterval(async function () {await updateChart(chart);}, 1000);  // 1000毫秒 = 1秒
});

sensordata.db文件放在本文顶部了有需要自取哦

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

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

相关文章

【uniapp/uview1.x】u-collapse 高度随内容自适应

当 u-collapse-items 中的内容为动态的时候&#xff0c;会发生这种情况&#xff1a; 在 uview 官网中有一个方法可以解决&#xff1a; 具体方法&#xff1a; 在 u-collapse 标签中配置 ref"collapse"&#xff1a; <u-collapse ref"collapse" :item-…

Golang | Leetcode Golang题解之第376摆动序列

题目&#xff1a; 题解&#xff1a; int wiggleMaxLength(int* nums, int numsSize) {if (numsSize < 2) {return numsSize;}int prevdiff nums[1] - nums[0];int ret prevdiff ! 0 ? 2 : 1;for (int i 2; i < numsSize; i) {int diff nums[i] - nums[i - 1];if ((…

使用notepad++将shell脚本转为UNIX格式方法(主要差别在换行符)

sh文件尽量在linux上改&#xff0c;因windows和linux换行符不同&#xff0c;在windows上改后&#xff0c;在linux上改可能会出现换行符错误。 windows换行符 linux换行符 windows环境改换行符方法 使用notepad点 编辑–》文档格式转换–》转换未unix格式。 注&#xff1a;tx…

C# 泛型类型的约束详解与示例

文章目录 一、泛型约束概述二、泛型约束详解与示例1. 类约束2. 接口约束3. 引用类型约束4. 值类型约束5. 无参数构造函数约束6、多重约束7、默认构造函数约束8、基类和接口的组合约束 三、总结 在C#编程语言中&#xff0c;泛型是一种非常强大的特性&#xff0c;它允许我们编写可…

鸿蒙卡片服务开发

首先先创建一个项目 在该项目下创建一个卡片服务 在module.json5文件下配置 {"module": {..."extensionAbilities": [{"name": "EntryFormAbility","srcEntry": "./ets/entryformability/EntryFormAbility.ets",…

Apache Tomcat与反向代理

Apache Tomcat 是一个开源的 Java Servlet 容器&#xff0c;主要用于部署和运行基于 Java 的 Web 应用程序。Tomcat 提供了一个环境&#xff0c;让开发者能够使用 Java 编写的 Web 应用程序在 Web 服务器上运行。下面是对 Tomcat 的详细介绍&#xff1a; Tomcat 的历史 Tomca…

Unity 中使用SQLite数据库

文章目录 0.参考文章1.Presentation —— 介绍2.&#xff08;SQLite4Unity3d&#xff09;Unity中直接使用SQLite的插件3.创建数据库4.创建表5.Navicat Premium&#xff08;数据库可视化&#xff09;6.增删改查6.1 增6.2 删6.3 改6.4 查 0.参考文章 https://blog.csdn.net/Chin…

干货 | 关于Armv7m异常进入的经验分享

一、 概述 这里主要介绍异常的进入行为&#xff08;不包括复位异常&#xff09;。&#xff08;这里主要参考 armv7m&#xff09;。 二、异常进入 在发生抢占的时候&#xff08;异常发生且开始执行&#xff09;&#xff0c;硬件将上下文状态保存到一个 SP 寄存器指向的栈中&a…

优化|贝叶斯优化系列(二):大规模贝叶斯优化算法

原文&#xff1a;When Gaussian Process Meets Big Data: A Reviewof Scalable GPs 原文作者&#xff1a;Haitao Liu , Yew-Soon Ong 论文解读者&#xff1a;赵进 编者按 高斯过程模型因其出色的预测性能在仿真建模中得到了广泛应用&#xff0c;然而在当今大数据时代&#xf…

百度翻译与TOP3在线翻译伙伴:2024年的黄金组合

在这个信息丰富的时代&#xff0c;语言帮助人们跨越地域界限进行交流。随着全球化的发展&#xff0c;高效的在线翻译工具变得越来越重要&#xff0c;它能帮我们更好地了解世界和不同的文化。今天&#xff0c;我们就来看看百度翻译和它的三个新对手之间的比较&#xff0c;一起找…

Codeforces Round 916 (Div. 3) E1. Game with Marbles(博弈论*1400)

感觉很难想。 如果你直接想的话&#xff0c;你就会发现有很多做法可以选择&#xff0c;而你根本不知道应该选哪个。 这时候可以先假设鲍勃已经取走了爱丽丝的所有的颜色的弹珠&#xff0c;&#xff08;并且以每个颜色一个弹珠的代价&#xff09;。 这时候每一项得分就是 S i …

Dubbo 内置容器:Spring Container

Dubbo 内置容器&#xff1a;Spring Container 1、核心点2、误解澄清 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; Dubbo本身并不直接提供容器服务&#xff0c;而是深度集成了Spring框架&#xff0c;实现了对Spring Container的全面支持。…

游戏开发设计模式之原型模式

目录 原型模式的实现步骤 原型模式的优点 原型模式的应用场景 总结 原型模式在游戏开发中的具体应用案例是什么&#xff1f; 如何在不同编程语言中实现原型模式&#xff1f; Java C# Python C JavaScript 原型模式与其他创建型设计模式&#xff08;如建造者模式、适…

Modern restaurant - building and interior (餐厅场景)

餐厅是模块化的,因此您可以使用提供的构造元素(如墙壁模块、地板模块、窗户、吧台、厨房模块、门、天花板模块等)进一步设计自己的餐厅。 图像和视频中显示的完整场景包含在此资源包中,可以用作游戏和3D项目的起点! ★ 主要特点 ★ 全模块化内饰和外观 全模块化厨房和餐厅…

PTA统计一行文本的单词个数

本题目要求编写程序统计一行字符中单词的个数。所谓“单词”是指连续不含空格的字符串&#xff0c;各单词之间用空格分隔&#xff0c;空格数可以是多个。 输入格式: 输入给出一行字符。 输出格式: 在一行中输出单词个数。 输入样例: Lets go to room 209.输出样例: 5解题…

【惠农网-注册安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…

Backtrader 实现和理解海龟交易法

Backtrader 实现和理解海龟交易法 1. 海龟交易的理解 &#xff08;1&#xff09;资金管理 海龟将总资金分为N个交易单位&#xff0c;每个单位即称为头寸&#xff0c;划分的标准主要是参考标的的波动性。 波动性用一个指标量化即真实波动幅度均值&#xff08;ATR&#xff09;…

C_05_编译4阶段

c语言编译的4个阶段&#xff1a;预处理、 编译、 汇编、 链接 预处理阶段会在源代码中查找预编译指令&#xff0c;其中主要是头文件展开&#xff08;include)&#xff0c;宏定义&#xff08;defind&#xff09;&#xff0c;选择性编译&#xff08;ifdef&#xff09;三种指令 预…

mybatis-plus添加replace(自定义)方法,添加sql注入器SqlInjector

1. 继承DefaultSqlInjector import com.baomidou.mybatisplus.core.injector.AbstractMethod; import com.baomidou.mybatisplus.core.injector.DefaultSqlInjector; import com.baomidou.mybatisplus.core.metadata.TableInfo; import org.springframework.stereotype.Compon…

Qt_信号槽机制

文章目录 Qt中的信号槽机制1.在widget.h添加处理函数的声明2.添加处理函数的定义3.建立信号和槽的连接4.运行 Qt中的信号槽机制 本质就是给按钮的点击操作&#xff0c;关联上一个处理函数&#xff0c;当用户点击的时候&#xff0c;就会执行这个处理函数。 函数&#xff1a;stat…