TODA(Train Operation Data Analysis)系统
一、系统概况- 开发框架:Django Rest Framework(后端)+Vue(前端)+Mysql(数据库)
- 版本信息:Django4.0/Vue3.2.33(Vue/cli 5.0.4)/Mysql8.0.25
- 开发环境:Pycharm/Vs code/Macos
- 数据基础:列车运行图实绩数据
- 数据的读取方法:ORM (object relational mapping)——原来的使用底层的 sql 语句,变成面向对象的开发,通过一系列对象的类定义和方法调用就可以 *** 作数据库
- 框架信息
- 列车运行实绩数据上传
- 列车运行图主要性能指标查询
- 列车数据查询
- 车站数据查询
- 晚点指标统计
- 冗余时间查询
- 作业间隔查询
- 上述数据可视化功能
- 机器学习预测晚点功能
- 关键运行线识别功能
django-admin startproject TODA
python manage.py runserver
-
http://127.0.0.1:8000/
-
localhost:8000
因为django默认的数据库为sqlite3,所以需要先修改“ENGINE”和“NAME”两个内容后自己输入相应的数据库信息,总体结构如下,其中“PASSWORD”是自己数据库对应的密码:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': '京沪运行图数据',
'USER': 'root',
'PASSWORD': 'hpr03260326',
'HOST': '127.0.0.1',
'PORT': '3306'
}
}
(2)如果提示需要安装对应的包如mysqlclient
在终端pip install mysqlclient
点击“+”号,数据源,Mysql,填写用户,密码,数据库,然后点击测试连接,如果提示安装组件安装即可,注意驱动程序要和Mysql的版本号对应,测试连接成功后点击应用、确定。
(4)数据迁移引入本地,在终端python manage.py migrate
,顺利后能在数据库表列表中看到以auth和django为前缀的10个表。
终端输入:python manage.py createsuperuser
,输入用户名,密码,邮箱。
进入管理员系统,项目启动的情况下在浏览器输入:http://127.0.0.1:8000/admin/
5.创建组件终端输入:python manage.py startapp Todaweb
,Todaweb就是后端组件,输入命令后项目里会多出Todaweb的文件夹
这里就需要在Todaweb/model.py下面进行 *** 作,通过ORM的方式创建数据结构,所谓ORM就是用类去对应数据表,用对象去映射数据行,用属性去匹配字段,具体代码如下:
from django.db import models
# Create your models here.
class operationdata(models.Model):
id = models.IntegerField(default=0, primary_key=True) # 序号
date = models.DateField(null=True) # 日期
trainid = models.CharField(max_length=255, blank=True, null=True) # 列车车次
ostation = models.CharField(max_length=255, blank=True, null=True) # 始发站
dstation = models.CharField(max_length=255, blank=True, null=True) # 终点站
nstation = models.CharField(max_length=255, blank=True, null=True) # 现在站
arr0 = models.CharField(max_length=255, blank=True, null=True) # 图定到达
dep0 = models.CharField(max_length=255, blank=True, null=True) # 图定出发
arr1 = models.CharField(max_length=255, blank=True, null=True) # 实际到达
dep1 = models.CharField(max_length=255, blank=True, null=True) # 实际出发
seq = models.IntegerField(default=0) # 站序
track = models.IntegerField(default=0) # 股道号
arrdelay = models.IntegerField(default=0) # 到达晚点
depdelay = models.IntegerField(default=0) # 图定晚点
# 这里时间还是字符串格式,需要处理
class Meta:
managed = False
db_table = 'operation_data'
7.功能注册
在写完model.py后,我们还需要在根目录Toda的settings.py进行对功能配置进行注册,具体 *** 作是在Installed_app中修改添加代码:Todaweb.apps.TodawebConfig
,这里Todaweb对应的是我们在step 5中创立的组件名称。
终端输入python manage.py makemigrations
,成功后Todaweb文件下的migrations文件下会有一个0001_initial.py文件
再在终端输入python manage.py migrate
,成功后终端提示applying 0001_initial…… OK,并且在数据库结构中可以看到。
在Todaweb目录下的admin.py中输入代码,整体结构如下:
from django.contrib import admin
from .models import operationdata
# Register your models here.
class TodawebAdmin(admin. ModelAdmin):
list_display = ["id", "date", "trainid", "ostation", "dstation",
"nstation", "arr0", "dep0", "arr1", "dep1", "seq", "track", "arrdelay", "depdelay"]
admin.site.register(operationdata, TodawebAdmin)
然后再次从终端启动项目python manage.py runserver
,进入http://127.0.0.1:8000/admin/后可以看到如下界面。
至此,关于项目结构建立已经完成,下一阶段是对前端项目的基础设置。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)