基于Django+Mysql+Echarts的可视化大屏开发

1 Big-screen项目说明

更多全面的可视化系统or大屏项目欢迎后台私我,技术分享!
课程实验作业,临时赶出来的一个可视化大屏,做的比较潦草。后端是Django实现的web框架+Mysql数据库;前端(HTML+CSS+JS)三剑客,图表控件Echarts;

运行效果如图(github项目地址在文末)
可视化大屏

2 数据来源及处理

数据源自国家数据统计局 ,将数据保存为csv文件,导入MySQL。
预先设计好数据库中的表字段,csv文件只保留需要的数据(如图 把csv文件前三行删掉),在Mysql workbench里右击表,选择Table Data Import Wizard导入csv文件。
在这里插入图片描述
在这里插入图片描述

3 Django框架

3.1 项目、应用的创建及运行

从命令行cd到您要存储代码的目录,然后运行以下命令:

$ django-admin startproject myweb 

创建应用程序,请确保您与目录位于同一目录,命令:

$ python manage.py startapp myapp

创建后,项目里面的内容如下:

[root@localhost demo]# tree myweb/
myweb/
├── manage.py
├── myweb
│   ├── __init__.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── myapp
    ├── admin.py
    ├── apps.py
    ├── __init__.py
    ├── migrations
    │   └── __init__.py
    ├── models.py
    ├── tests.py
    └── views.py

运行开发服务器

$ python manage.py runserver 端口号(默认8000)

3.2 连接数据库

在myweb/settings.py文件中,通过DATABASES项进行数据库设置,默认是使用SQLite,我用的是MySQL,修改一下配置

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'mydemo',#数据库的名字,提前在mysql创建
        'USER': 'root',
        'PASSWORD': '', #这里填上你的密码
        'HOST': 'localhost',
        'PORT': '3306',
    }
}

3.3 模板层

模板包含所需HTML 输出的静态部分,以及一些特殊的语法,描述如何将动态内容插入。在项目的根目录下创建一个templates目录,配置:

# 项目目录下的settings.py配置文件添加TEMPLATES中的DIRS配置
TEMPLATES = [
        {
            'BACKEND': 'django.template.backends.django.DjangoTemplates',
            'DIRS': [os.path.join(BASE_DIR,'templates')],
            'APP_DIRS': True,
            'OPTIONS': {
                'context_processors': [
                    'django.template.context_processors.debug',
                    'django.template.context_processors.request',
                    'django.contrib.auth.context_processors.auth',
                    'django.contrib.messages.context_processors.messages',
                ],
            },
        },
    ]

3.4 其他核心功能

项目中会用到CSS、图片、js等静态文件,在项目目录下新建一个名为static的文件夹,用于存放以上文件,需要在settings 文件中定义静态内容

STATIC_URL = '/static/'
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static'),
]## 标题

Django虽然上手快,但功能、框架内容还是比较多的,如果你还不太了解,建议先熟悉一下框架(不要心急哦,一步一步慢慢来)

4 核心功能代码分析

4.1 统计信息展示及管理

a. 信息展示

大屏右下角的图表,展示了各年份-月份的失业率调查情况。大屏右上角是使用Echarts做的一个饼图。如果你只想做一个无后端的前端页面,可以直接写静态数据,图表的js代码在echarts都有给,自己根据需求修改配置项即可

<body>
                    <script type="text/javascript">
                    var myChart = echarts.init(document.getElementById('main')); 
                    var option;
                    option = {
                    tooltip: {
                        trigger: 'item'
                    },
                    legend: {
                        top: '0%',
                        left: 'center'
                    },
                    series: [
                        {
                        name: 'Access From',
                        type: 'pie',
                        radius: ['40%', '70%'],
                        avoidLabelOverlap: false,
                        itemStyle: {
                            borderRadius: 15,
                            borderColor: '#fff',
                            borderWidth: 2
                        },
                        label: {
                            show: false,
                            position: 'center'
                        },
                        emphasis: {
                            label: {
                            show: true,
                            fontSize: 20,
                            fontWeight: 'bold'
                            }
                        },
                        labelLine: {
                            show: false
                        },
                        data: [
                            { value: 5.6, name: '全国城镇调查失业率(%)',itemStyle: { color: '#4682B4' } },
                            { value: 5.4, name: '全国本地户籍人口城镇调查失业率(%)',itemStyle: { color: '#F4A460' } },
                            { value: 18.1, name: '全国16-24岁人口城镇调查失业率(%)',itemStyle: { color: '#FF8C00' } },
                            { value: 4.8, name: '全国25-59岁人口城镇调查失业率(%)',itemStyle: { color: '#FFF5EE' } },
                            { value: 5.7, name: '31个大城市城镇调查失业率(%)',itemStyle: { color: '	#AFEEEE' } }
                        ]
                        }
                    ]
                    }; 
                    myChart.setOption(option);
                </script>
                </body>

b. 信息后台管理

右下角的图表,有一个橙色的文字加载更多,点击这个,会跳转到信息统计管理的页面
在这里插入图片描述
以上数据是从数据库获取的,刚才我们已经连接了数据库,现在需要将数据库中具体的表映射到模型上,在models.py中定义模型类,要求继承自models.Model

from django.db import models

# Create your models here.
class UPR(models.Model):
    '''自定义表对应的Model类'''
    #定义属性:默认主键自增id字段可不写
    id = models.AutoField(primary_key=True)
    time = models.CharField(max_length=45)
    uprate_1 = models.CharField(max_length=45)
    uprate_2 = models.CharField(max_length=45)
    uprate_3 = models.CharField(max_length=45)

    # 定义默认输出格式
    def __str__(self):
        return "%d:%s:%s:%s:%s"%(self.id,self.time,self.uprate_1,self.uprate_2,self.uprate_3)

    # 自定义对应的表名
    class Meta:
        db_table="unemployment"

之后就可以开始写每个操作相应的函数了
在这里插入图片描述
写好后完成路由配置
在这里插入图片描述
前端通过路由反向解析,做出响应
在这里插入图片描述

4.2 Ajax异步请求

ajax 是一种浏览器通过 js 异步发起请求, 局部更新页面的技术。通过后台与服务器进行少量数据交换,ajax可以使网页实现异步更新。

在说明Ajax技术之前,先串一下大致流程,明确ajax写在哪?干了些什么?

  • 前端页面分区
    big-screen划分了四个模块,在前端页面html文件中,为每个模块划分区域,放在div标签里
    在这里插入图片描述

  • 初始化echarts实例
    避免一大串代码出现在div里,我们把初始化实例的工作写在js里,注意id要对应上。
    在这里插入图片描述
    接着把js文件放到head标签里,这里我加了版本号version(因为,有时候出现修改项目js文件浏览器不能及时更新的情况,这是因为浏览器默认是有缓存的,会影响我们的调试工作,通过设置和改变版本号,浏览器就会重新下载新的js文件)

<script language="javascript" src="static/js/myec.js?version=1.0.2"></script>
  • 使用Ajax传递数据
    传递的数据是用于Echarts实例的,所以把ajax传递数据的工作写在同一个js文件里。使用get()方法请求数据,先简单看一下语法

    $.get()函数语法
    $.get(url,[data],[callback])
    url:(string)‘请求的URL地址’请输入自己需要的地址
    data:(object)请求资源期间要携带的参数
    callback:(function)请求成功时的回调函数
    

    为此我们需要定义一个用于请求的URL地址,并能够返回数据。在视图层编写getData(),并配置路由即可
    在这里插入图片描述在这里插入图片描述

    这时候,就可以通过ajax异步发送请求了,此外还通过setTimeOut()设置了刷新时间。在这里插入图片描述
    big-screen左上角模块也是通过ajax技术实现的前后端交互,操作大差不差,就不多赘述了,上个动图看看效果
    在这里插入图片描述

5 总结

github项目地址: https://github.com/goldikfish/Bigscreen.git

项目没有花太多时间(临时的作业),用的技术都比较简单,整体效果也略显简陋了。之后做大屏,可以考虑用华为云的DLV或者Astro轻应用(低代码),有很多现成的组件。
在这里插入图片描述
做数据可视化的本意是呈现数据的价值,后续深入学习,要对数据做好处理和分析,借助数理统计的知识,选用合理的图表进行可视化;再是技术层面的优化,比如前端采用vue框架,数据分布式存储等等,让项目更具现实意义。

文章内容只涉及比较关键的技术,具体代码见GitHub,最后,总结一下具体实现方案:

  1. 确定数据来源和数据格式。您可以从公开的数据接口或自行采集数据,将数据存储到MySQL数据库中,格式可以选择适合echarts组件的格式,如JSON格式。

  2. 在Django项目中创建一个应用,并定义模型类,用于操作MySQL数据库中的数据。

  3. 创建视图函数,用于接收前端请求,从数据库中获取数据,并返回JSON格式的数据给前端。

  4. 在前端页面中引入echarts组件,创建图表,读取后端返回的JSON格式数据,更新图表数据。

  5. 实现前后端异步交互,使用Ajax技术,发送请求给后端,获取数据,并更新前端页面。

  6. 在前端页面中使用JavaScript语言处理DOM操作,实现动态页面效果。

这是一个简单的实现方案,具体实现过程中可能还需要做一些细节处理。希望对您有所帮助。

### 使用 Django 实现可视化 #### 构建环境与安装依赖库 为了构建基于 DjangoPython 可视化应用,需先搭建好开发环境并安装必要的软件包。这通常涉及配置虚拟环境以及利用 pip 安装诸如 `pyecharts` 和其他可能需要用到的数据分析工具。 ```bash pip install django pyecharts pandas ``` #### 设计模型层 (Model Layer) 根据项目需求定义相应的数据库结构,在此案例中假设有一个用于存储气象观测记录的简单表格: ```python from django.db import models class WeatherObservation(models.Model): date = models.DateField() temperature = models.FloatField() humidity = models.FloatField() class Meta: db_table = 'weather_observations' ``` #### 开发视图逻辑 (View Logic) 创建一个专门负责渲染图表页面的视图函数,并在此处集成 PyEcharts 来生成所需的统计图形。下面是一个简单的例子展示了如何在一个网页内嵌入多个不同类型的图表。 ```python import json from django.shortcuts import render from .models import WeatherObservation from pyecharts.charts import Line, Pie from pyecharts import options as opts def dashboard(request): observations = WeatherObservation.objects.all().order_by('date') dates = list(observations.values_list('date', flat=True)) temperatures = list(observations.values_list('temperature', flat=True)) humidities = list(observations.values_list('humidity', flat=True)) line_chart = ( Line(init_opts=opts.InitOpts(width="800px", height="400px")) .add_xaxis(dates) .add_yaxis("Temperature", temperatures) .set_global_opts(title_opts=opts.TitleOpts(title="Daily Temperature Trend")) ) pie_data = [("High Temp.", sum([t>25 for t in temperatures])), ("Normal Temp.", sum((15<=t<25)for t in temperatures)), ("Low Temp.", sum(t<15 for t in temperatures))] pie_chart = ( Pie(init_opts=opts.InitOpts(width="600px", height="300px")) .add("", [list(z) for z in zip(*pie_data)]) .set_global_opts(title_opts=opts.TitleOpts(title="Temperature Distribution")) ) context = { "line_chart": line_chart.dump_options(), "pie_chart": pie_chart.dump_options(), } return render(request, 'dashboard.html', context=context) ``` 上述代码片段实现了温度趋势折线图和温区分布饼形图的同时呈现[^1]。 #### 渲染前端模板 (Frontend Template Rendering) 在 templates 文件夹下新建名为 `dashboard.html` 的文件,用来加载由后端传递过来的 JSON 数据并通过 JavaScript 动态插入到 DOM 中完成最终效果展现。 ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Django Visualization Dashboard</title> <script src="https://cdn.jsdelivr.net/npm/echarts@latest/dist/echarts.min.js"></script> <style type="text/css"> .container { display: flex; justify-content: space-around;} .chart-container { width: 50%; margin-bottom: 2em;} </style> </head> <body> <div class="container"> <div id="line-chart" class="chart-container"></div> <div id="pie-chart" class="chart-container"></div> </div> <script type="text/javascript"> var lineChartDom = document.getElementById('line-chart'); var myLineChart = echarts.init(lineChartDom); myLineChart.setOption(JSON.parse('{{ line_chart|safe }}')); var pieChartDom = document.getElementById('pie-chart'); var myPieChart = echarts.init(pieChartDom); myPieChart.setOption(JSON.parse('{{ pie_chart|safe }}')); </script> </body> </html> ``` 这段 HTML 片段设置了两个容器分别容纳两种不同的 ECharts 图表实例,并通过 AJAX 请求获取来自服务器端的数据源信息来初始化这些图表对象[^3]。
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值