【flask框架搭建服务器demo】Python 使用轻量级 Flask 框架搭建 Web 服务器可视化数据库数据demo
创始人
2024-09-25 03:45:41
0

本文适合刚入门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.Row     return 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文件

                 Environmental Data Visualization            

(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文件放在本文顶部了有需要自取哦

相关内容

热门资讯

win系统安装安卓软件,一站式... 揭秘!Win系统安装安卓软件,轻松玩转双系统亲爱的电脑迷们,你是否曾想过在Windows系统上也能畅...
安卓变ios系统锁定,解锁隐私... 你有没有想过,如果你的安卓手机突然变成了苹果的iOS系统,那会是怎样的体验呢?想象你的手机屏幕上不再...
mib是否支持安卓系统,创新车... 亲爱的车友们,你们有没有想过,你的爱车MIB系统是不是也能和你的安卓手机来个亲密接触呢?今天,就让我...
安卓机器升级鸿蒙系统,操作指南... 亲爱的读者们,你们有没有想过,你的安卓机器升级鸿蒙系统后会发生什么奇妙的事情呢?今天,就让我带你一起...
闹钟安卓系统个人总结,闹钟安卓... 闹钟,这个看似普通的小玩意儿,却在我日常生活中扮演着不可或缺的角色。自从我拥有了安卓手机,这个系统自...
华为安卓系统不能更新,迈向自主... 最近网上闹得沸沸扬扬的,说华为的安卓系统不能更新了,这可把咱们这些华为手机用户给急坏了。别急,别急,...
苹果系统安装安卓应用,轻松体验... 亲爱的果粉们,你是不是也和我一样,对安卓应用爱得深沉呢?虽然苹果手机自带的应用商店琳琅满目,但有时候...
安卓机重装系统windows系... 亲爱的手机控们,你们有没有想过,你的安卓手机也能变身成Windows系统的超级战士呢?没错,就是那个...
安卓系统安装xp系统教程视频,... 你有没有想过,在手机上也能玩Windows XP呢?没错,就是那个经典的操作系统,现在它竟然能在安卓...
游戏手机推荐安卓系统,性能与体... 你有没有想过,一款好的游戏手机,就像是你的游戏世界里的超级英雄呢?它不仅能让你在虚拟的世界里所向披靡...
安卓系统都是通用吗,通用性与个... 你有没有想过,安卓系统是不是真的像它的名字一样,通用到无处不在呢?咱们今天就来聊聊这个话题,看看安卓...
安卓系统视频倍速播放,倍速播放... 亲爱的手机控们,你是否有过这样的经历:一部精彩的电影,一部有趣的纪录片,或者一段重要的教学视频,因为...
苹果手机壁纸安卓系统,苹果手机... 哇塞,你有没有发现,手机壁纸可是我们个性展示的小天地呢!想象每天看着自己心爱的手机,背景是你的最爱,...
苹果手机说安卓系统,兼容性与创... 你知道吗?在这个科技飞速发展的时代,手机已经成为了我们生活中不可或缺的好伙伴。而说到手机,那可真是各...
安卓系统广告怎么关,享受纯净体... 手机里的广告是不是让你烦得要命?别急,今天就来教你几招,让你轻松告别安卓系统广告的烦恼!一、设置篇:...
hinova属于安卓系统吗,体... 你有没有听说过hinova这个牌子?最近,它可是手机圈里的小热门呢!不过,说到hinova,你是不是...
安卓手机开启双系统,安卓手机开... 你有没有想过,你的安卓手机也能变身成“双胞胎”呢?没错,就是那种一个手机里藏着两个系统的神奇操作!是...
小米安卓系统设置下载,轻松设置... 亲爱的米粉们,你是否曾为小米安卓系统的设置和下载而烦恼?别担心,今天我要带你一起探索这个神秘的世界,...
安卓平板适配鸿蒙系统,体验全新... 你知道吗?最近科技圈可是炸开了锅,因为安卓平板适配鸿蒙系统这个大事件,让不少平板用户都兴奋不已。想象...
小米手机提示安卓系统,解锁手机... 亲爱的手机控们,你们有没有遇到过这种情况:你的小米手机突然跳出来一个提示,告诉你安卓系统需要更新啦!...