数据统计与可视化的Dash应用程序

在数据分析和可视化领域,Dash是一个强大的工具,它结合了Python中的数据处理库(如pandas)和交互式可视化库(如Plotly)以及Web应用程序开发框架。本文将介绍如何使用Dash创建一个简单的数据统计和可视化应用程序,从Microsoft Access数据库中获取数据并在Web界面上展示。C:\pythoncode\new\dashboard.py
在这里插入图片描述

在这里插入图片描述

首先,我们需要使用pyodbc库连接到Microsoft Access数据库。在示例代码中,我们连接到名为"database1.accdb"的数据库文件。你需要根据自己的情况修改连接字符串和数据库文件路径。

以下是连接到数据库的代码示例:

import pyodbc# 连接到数据库
conn = pyodbc.connect('DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=./database1.accdb')

接下来,我们定义了一个查询函数(query_data),该函数执行一条SQL查询语句,计算了文章阅读量、评论数、关注数和收藏数的总和。查询结果被转换为一个DataFrame对象,方便后续处理和展示。

以下是查询函数的代码示例:

import pandas as pd# 定义查询函数
def query_data():# 创建游标cursor = conn.cursor()# 执行查询cursor.execute("SELECT SUM(阅读量) AS 阅读量总数, SUM(评论数) AS 评论数总数, SUM(关注数) AS 关注数总数, SUM(收藏数) AS 收藏数总数 FROM articles")data = cursor.fetchone()# 将查询结果转换为列表data_list = list(data)# 将列表转换为DataFramedf = pd.DataFrame([data_list], columns=['阅读量总数', '评论数总数', '关注数总数', '收藏数总数'])return df

使用Dash库创建应用程序的过程非常简单。我们创建一个Dash应用程序实例,并设置应用程序的布局。在示例代码中,我们创建了一个包含标题和数据表格的Div容器。数据表格使用HTML的table元素进行展示,包括表头和表体,显示了查询结果。

以下是创建应用程序布局的代码示例:

from dash import Dash, dcc, html# 创建Dash应用程序
app = Dash(__name__)# 创建布局
app.layout = html.Div(children=[html.H1(children='数据统计'),html.Table(children=[html.Thead(html.Tr([html.Th('指标'), html.Th('数量')])),html.Tbody([html.Tr([html.Td('阅读量'), html.Td(df['阅读量总数'])]),html.Tr([html.Td('评论数'), html.Td(df['评论数总数'])]),html.Tr([html.Td('关注数'), html.Td(df['关注数总数'])]),html.Tr([html.Td('收藏数'), html.Td(df['收藏数总数'])])])])]
)

最后,我们运行应用程序,通过调用app.run_server(debug=True)启动Web服务器,将应用程序部署到本地。你可以在浏览器中访问指定的URL,即可看到展示查询结果的网页。

以下是运行应用程序的代码示例:

# 运行应用程序
if __name__ == '__main__':app.run_server(debug=True)

通过这个简单的示例,你可以根据自己的需求扩展应用程序。你可以添加更多的查询函数和数据处理逻辑,创建更复杂的可视化图表,并将其与Dash的其他组件结合使用,以实现更丰富的数据分析和可视化功能。
全部代码

import pyodbc
import pandas as pd
from dash import Dash
from dash import dcc
from dash import html
import plotly.graph_objs as go# 连接到数据库
conn = pyodbc.connect('DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=./database1.accdb')# 定义查询函数
def query_data():# 创建游标cursor = conn.cursor()# 执行查询cursor.execute("SELECT SUM(阅读量) AS 阅读量总数, SUM(评论数) AS 评论数总数, SUM(关注数) AS 关注数总数, SUM(收藏数) AS 收藏数总数 FROM articles")data = cursor.fetchone()# 将查询结果转换为列表data_list = list(data)# 将列表转换为DataFramedf = pd.DataFrame([data_list], columns=['阅读量总数', '评论数总数', '关注数总数', '收藏数总数'])return df# 查询数据
df = query_data()# 创建Dash应用程序
app = Dash(__name__)# 创建布局
app.layout = html.Div(children=[html.H1(children='数据统计'),html.Table(children=[html.Thead(html.Tr([html.Th('指标'), html.Th('数量')])),html.Tbody([html.Tr([html.Td('阅读量'), html.Td(df['阅读量总数'])]),html.Tr([html.Td('评论数'), html.Td(df['评论数总数'])]),html.Tr([html.Td('关注数'), html.Td(df['关注数总数'])]),html.Tr([html.Td('收藏数'), html.Td(df['收藏数总数'])])])])]
)# 运行应用程序
if __name__ == '__main__':app.run_server(debug=True)# 关闭数据库连接
conn.close()

Dash提供了丰富的文档和示例,可以帮助你更深入地了解和使用该库。你可以访问Dash官方网站(https://dash.plotly.com/ ↗)查看更多资料和示例代码。

总结起来,Dash是一个强大的工具,可以帮助你快速创建数据统计和可视化的Web应用程序。通过使用Dash,你可以轻松地从各种数据源获取数据,并将其以交互式和可视化的方式展示出来。

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

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

相关文章

使用 BERT 进行文本分类 (02/3)

​ 一、说明 在使用BERT(1)进行文本分类中,我向您展示了一个BERT如何标记文本的示例。在下面的文章中,让我们更深入地研究是否可以使用 BERT 来预测文本是使用 PyTorch 传达积极还是消极的情绪。首先,我们需要准备数据…

冉冉升起的星火,再度升级迎来2.0时代!

文章目录 前言权威性评测结果 星火大模型多模态功能插件功能简历生成文档问答PPT生成 代码能力 福利 前言 前几天从技术群里看到大家都在谈论《人工智能大模型体验报告2.0》里边的内容,抱着好奇和学习的态度把报告看了一遍。看完之后瞬间被里边提到的科大讯飞的星火…

PHP实现在线年龄计算器

1. 输入日期查询年龄 2. php laravel框架实现 代码 /*** 在线年龄计算器*/public function ageDateCal(){// 输入的生日时间$birthday $this->request(birthday);// 当前时间$currentDate date(Y-m-d);// 计算周岁$age date_diff(date_create($birthday), date_create($…

SQL Server基础之游标

一:认识游标 游标是SQL Server的一种数据访问机制,它允许用户访问单独的数据行。用户可以对每一行进行单独的处理,从而降低系统开销和潜在的阻隔情况,用户也可以使用这些数据生成的SQL代码并立即执行或输出。 1.游标的概念 游标是…

LiveDataBus 其中的一个库LiveEventBus库的源码解析

EventBus事件通知的框架我们用了很久了,随着LiveData的出现,出现了LiveDataBus来替代EventBus,因为LiveDataBus 会考虑生命周期,EventBus你可能要注意在生命周期结束的时候unregister的,否则会有内存泄漏等问题,而Live…

采用pycharm在虚拟环境使用pyinstaller打包python程序

一年多以前,我写过一篇博客描述了如何虚拟环境打包,这一次有所不同,直接用IDE pycharm构成虚拟环境并运行pyinstaller打包 之前的博文: 虚拟环境venu使用pyinstaller打包python程序_伊玛目的门徒的博客-CSDN博客 第一步&#xf…

【深入了解PyTorch】PyTorch模型解释性和可解释性:探索决策过程与预测结果的奥秘

【深入了解PyTorch】PyTorch模型解释性和可解释性:探索决策过程与预测结果的奥秘 PyTorch模型解释性和可解释性:探索决策过程与预测结果的奥秘1. 引言2. 梯度可视化3. 特征重要性分析4. 结论PyTorch模型解释性和可解释性:探索决策过程与预测结果的奥秘 在机器学习和深度学习…

临床试验设计-平行设计、析因设计、交叉设计

平行设计、析因设计、交叉设计是临床试验中最重要的三种设计方法。 平行设计:最常见 交叉设计:生物等效性试验 析因设计:药物配伍 一、平行设计 双臂试验(two-arm study)(两组):试验…

Steam 灵感的游戏卡悬停效果

先看效果&#xff1a; 再看代码&#xff08;查看更多&#xff09;&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Steam 灵感的游戏卡悬停效果</title><style>* {margin: …

【IMX6ULL驱动开发学习】04.应用程序和驱动程序数据传输和交互的4种方式:非阻塞、阻塞、POLL、异步通知

一、数据传输 1.1 APP和驱动 APP和驱动之间的数据访问是不能通过直接访问对方的内存地址来操作的&#xff0c;这里涉及Linux系统中的MMU&#xff08;内存管理单元&#xff09;。在驱动程序中通过这两个函数来获得APP和传给APP数据&#xff1a; copy_to_usercopy_from_user …

【Docker】Docker network之bridge、host、none、container以及自定义网络的详细讲解

&#x1f680;欢迎来到本文&#x1f680; &#x1f349;个人简介&#xff1a;陈童学哦&#xff0c;目前学习C/C、算法、Python、Java等方向&#xff0c;一个正在慢慢前行的普通人。 &#x1f3c0;系列专栏&#xff1a;陈童学的日记 &#x1f4a1;其他专栏&#xff1a;CSTL&…

分布式定时任务系列5:XXL-job中blockingQueue的应用

传送门 分布式定时任务系列1&#xff1a;XXL-job安装 分布式定时任务系列2&#xff1a;XXL-job使用 分布式定时任务系列3&#xff1a;任务执行引擎设计 分布式定时任务系列4&#xff1a;任务执行引擎设计续 Java并发编程实战1&#xff1a;java中的阻塞队列 引子 这篇文章的…

二.net core 自动化发布到docker (Jenkins安装之后向导)

目录 ​​​​​​​​​​​​​​ 参考资料&#xff1a;https://www.jenkins.io/doc/book/installing/docker/#setup-wizard Post-installation setup wizard.(安装后安装向导) 基于上一篇文章安装&#xff0c;在安装并运行Jenkins&#xff08;不包括使用Jenkins Opera…

日志采集分析ELK

这里的 ELK其实对应三种不同组件 1.ElasticSearch&#xff1a;基于Java&#xff0c;一个开源的分布式搜索引擎。 2.LogStash&#xff1a;基于Java&#xff0c;开源的用于收集&#xff0c;分析和存储日志的工具。&#xff08;它和Beats有重叠的功能&#xff0c;Beats出现之后&a…

6.3 社会工程学攻击

数据参考&#xff1a;CISP官方 目录 社会工程学攻击概念社会工程学攻击利用的人性 “弱点”典型社会工程学攻击方式社会工程学攻击防护 一、社会工程学攻击概念 什么是社会工程学攻击 也被称为 "社交工程学" 攻击利用人性弱点 (本能反应、贪婪、易于信任等) 进…

Reis过期删除策略

介绍 在Redis中&#xff0c;我们可以为键值对设置有效期&#xff0c;现在面临一个问题&#xff0c;如果一个键值对过期了&#xff0c;那么我们应该怎么删除呢&#xff1f; 我们目前有三种方案&#xff1a; 定时删除&#xff1a;在设置键的过期时间的同时&#xff0c;为此键设…

小游戏扫雷实现教学(详解)

目录 【前言】 一、模块化程序设计&#xff08;多文件编程&#xff09;介绍 1.概述 2.传统编程的方式 3.模块化程序设计的方法 二、扫雷代码设计思路 三、扫雷代码设计 1.创建菜单函数 2.实现9x9扫雷 3.初始化棋盘 4.打印棋盘 5.随机布置雷的位置 6.排查雷的信息 7.回…

【Apollo】推动创新:探索阿波罗自动驾驶的进步(含安装 Apollo的详细教程)

前言 Apollo (阿波罗)是一个开放的、完整的、安全的平台&#xff0c;将帮助汽车行业及自动驾驶领域的合作伙伴结合车辆和硬件系统&#xff0c;快速搭建一套属于自己的自动驾驶系统。 开放能力、共享资源、加速创新、持续共赢是 Apollo 开放平台的口号。百度把自己所拥有的强大、…

2023年7月京东冰箱行业品牌销售排行榜(京东运营数据分析)

作为日常使用的大家电之一&#xff0c;如今我国冰箱产业已渐趋饱满&#xff0c;市场增长有限。今年上半年&#xff0c;冰箱市场整体销额同比去年来看勉强保持小幅增长。不过&#xff0c;7月份&#xff0c;冰箱大盘的销售表现就略显萧条了。 根据鲸参谋电商数据分析平台的相关数…

NPM与外部服务的集成(下)

目录 1、撤消访问令牌 2、在CI/CD工作流中使用私有包 2.1 创建新的访问令牌 持续整合 持续部署 交互式工作流 CIDR白名单 2.2 将令牌设置为CI/CD服务器上的环境变量 2.3 创建并签入特定于项目的.npmrc文件 2.4 令牌安全 3、Docker和私有模块 3.1 背景&#xff1a;运…