数据统计与可视化的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.hqwc.cn/news/69455.html

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

相关文章

Mysql - 配置Mysql主从复制-keepalived高可用-读写分离集群

目录 高可用: 为什么需要高可用呢? 高可用的主要作用: keepalived是什么?它用在哪里? 什么是VRRP协议,它的作用是什么? 搭建一个基于keepalived的高可用Mysql主从复制读写分离集群 一、项…

HTML5的介绍和基本框架

目录 HTML5 HTML5介绍 HTML5的DOCTYPE声明 HTML5基本骨架 html标签 head标签 body标签 title标签 meta标签 在vscode中写出第一个小框架 HTML5 HTML5介绍 HTML5是用来描述网页的一种语言,被称为超文本标记语言。用HTML5编写的文件,后缀以.ht…

ubuntu网络管理

主机-ip,service—port 分别查看/etc/hosts,/etc/host.conf;/etc/services,/etc/resolv.conf; 内核更新——linux-image-generic 6.2.0-24.24 非常抱歉,我误解了你的问题。如果你想更新已安装的内核版本…

centos7安装erlang及rabbitMQ

下载前注意事项: 第一:自己的系统版本,centos中uname -a指令可以查看,el8,el7,rabbitMQ的包不一样! 第二:根据rabbitMQ中erlang version找到想要下载rabbitMQ对应erlang版本&#x…

18----找出第一个只出现一次的字符(桶计数法/4种思路讲解)

题目描述 给定一个只包含小写字母的字符串,请你找到第一个仅出现一次的字符。如果没有,输出 no。 输入格式 一个字符串,长度小于 1100。 输出格式 输出第一个仅出现一次的字符,若没有则输出 no。 输入输出样例 输入 #1复制 abc 输…

Android Studio System.out.println()中文乱码

第一步: 打开studio64.exe.vmoptions加入-Dfile.encodingUTF-8 第二步: File-Settings-Editor-File Encodings 把所有的编码格式改为UTF-8 尝试跑一下代码,如果还不行,重启IDE 再试试。

Linux MQTT智能家居项目(LED界面的布局设置)

文章目录 前言一、LED界面布局准备工作二、LED界面布局三、逻辑实现总结 前言 上篇文章我们完成了主界面的布局设置那么这篇文章我们就来完成各个界面的布局设置吧。 一、LED界面布局准备工作 首先添加LED灯光控制的图标。 将选择好的LED图标添加进来: 图标可以…

Centos7完全卸载已安装的Nginx

查看服务器上安装的nginx版本号,主要是通过ngix的-v或-V选项 Linux下查看Nginx安装目录、版本号信息? -v 显示 nginx 的版本。 -V 显示 nginx 的版本,编译器版本和配置参数。 [rootwww ~]# /usr/local/nginx/sbin/nginx -v nginx version: nginx/1.…

VR时代真的到来了?

业界对苹果的期待是,打造一台真正颠覆性的,给头显设备奠定发展逻辑底座的产品,而实际上,苹果只是发布了一台更强大的头显。 大众希望苹果回答的问题是“我为什么需要一台AR或者VR产品?”,但苹果回答的是“…

MFC为控件添加背景图片

1、 添加选择Bitmap导入图片,图片文件最好放在项目res目录中,同时是BMP格式。上传后的图片在资源视图,命名为IDB_BITMAP_M_BACK。 2、在cpp的C***Dlg::OnPaint()函数下添加如下代码 void C***Dlg::OnPaint() {CPaintDC dc(this); // device…

设计模式(6)原型模式

一、介绍 Java中自带的原型模式是clone()方法。该方法是Object的方法,native类型。他的作用就是将对象的在内存的那一块内存数据一字不差地再复制一个。我们写简单类的时候只需要实现Cloneable接口,然后调用Object::clone方法就可实现克隆功能。这样实现…

Ansys Zemax | 大功率激光系统的 STOP 分析(四)

大功率激光器广泛用于各种领域当中,例如激光切割、焊接、钻孔等应用中。由于镜头材料的体吸收或表面膜层带来的吸收效应,将导致在光学系统中由于激光能量吸收所产生的影响也显而易见,大功率激光器系统带来的激光能量加热会降低此类光学系统的…