1. 创建应用App

      1. python manage.py startapp RepairApp
  2. 创建模型

    在models.py文件中定义一个Repair模型来表示报修单,其中包含以下字段:

    • repair_id: 报修单号
    • repair_time: 报修时间
    • repair_person: 报修人
    • problem_description: 问题描述
    • service_person: 接单人
    • response_time: 首次回应时间
    • progress: 处理进度
      1. from django.db import models
      2.  
      3. # Create your models here.
      4. from django.db import models
      5. import datetime
      6.  
      7. from django.db.models.signals import pre_save
      8. from django.dispatch import receiver
      9.  
      10. # 报修单状态choices
      11. STATUS_CHOICES = (
      12. ('1', '待受理'),
      13. ('2', '处理中'),
      14. ('3', '已完成'),
      15. ('4', '已撤销'),
      16. )
      17.  
      18. class Repair(models.Model):
      19. repair_id = models.CharField(max_length=20, unique=True, verbose_name="报修单号")
      20. repair_time = models.DateTimeField(auto_now_add=True, verbose_name="报修时间")
      21. emp_id = models.CharField(max_length=20)
      22. repair_person = models.CharField(max_length=20, verbose_name="报修人")
      23. repair_description = models.TextField(verbose_name="问题描述")
      24. receiver = models.CharField(max_length=20, verbose_name="接单人", null=True, blank=True)
      25. first_response_time = models.DateTimeField(null=True, blank=True, verbose_name="首次回应时间")
      26. process_status = models.CharField(max_length=1, choices=STATUS_CHOICES, default='1', verbose_name="处理进度")
      27. created_time = models.DateTimeField(auto_now_add=True, verbose_name="创建时间")
      28. update_time = models.DateTimeField(auto_now=True, verbose_name="最后修改时间")
      29.  
      30. def __str__(self):
      31. return self.repair_id
      32.  
      33. class Meta:
      34. verbose_name = "报修单"
      35. verbose_name_plural = "报修单"
      36. ordering = ['-repair_time']
      37.  
      38. @receiver(pre_save, sender=Repair)
      39. def auto_generate_repair_id(sender, instance, **kwargs):
      40. if not instance.repair_id:
      41. # 生成年月
      42. year_month = datetime.datetime.now().strftime("%Y%m")
      43. # 查找当月最大的流水号
      44. last_repair = Repair.objects.filter(repair_id__startswith=year_month).order_by('-repair_id').first()
      45. if last_repair:
      46. # 如果存在,流水号为最大报修单号加1
      47. max_id = int(last_repair.repair_id[-4:])
      48. new_id = f"{year_month}{max_id + 1:04}"
      49. else:
      50. # 如果不存在,流水号从0001开始
      51. new_id = f"{year_month}0001"
      52. instance.repair_id = new_id

Django4全栈进阶之路21 项目实战(在线报修):创建App应用和Model模型的更多相关文章

  1. Python Django CMDB项目实战之-2创建APP、建模(models.py)、数据库同步、高级URL、前端页面展示数据库中数据

    基于之前的项目代码来编写 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页index页文章页面 现在我们修改一个文章列表是从数据库中获取数据, 下面我们就需 ...

  2. Python Django CMDB项目实战之-3创建form表单,并在前端页面上展示

    基于之前的项目代码 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页.index页.文章页面 Python Django CMDB项目实战之-2创建APP. ...

  3. web前端全栈学习之路

    web前端全栈学习之路 --- 陆续更新中 一.HTML相关 1.HTML常用标签:http://www.cnblogs.com/wyb666/p/8733699.html 2.HTML5基础: 3. ...

  4. python 全栈开发之路 day1

    python 全栈开发之路 day1   本节内容 计算机发展介绍 计算机硬件组成 计算机基本原理 计算机 计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可 ...

  5. 你的Node应用,对接分布式链路跟踪系统了吗?(一) 原创: 金炳 Node全栈进阶 4天前 戳蓝字「Node全栈进阶」关注我们哦

    你的Node应用,对接分布式链路跟踪系统了吗?(一) 原创: 金炳 Node全栈进阶 4天前 戳蓝字「Node全栈进阶」关注我们哦

  6. C#.Net全栈工程师之路-学习路径

    C#.Net全栈工程师之路-学习路径 按架构分: C/S架构: B/S架构: Mobile移动开发: 按技术点分: C#编程基础以及OOP面向对象编程: 数据库基础以及高级应用(MYSQL+MSSQL ...

  7. 战争热诚的python全栈开发之路

    从学习python开始,一直是自己摸索,但是时间不等人啊,所以自己为了节省时间,决定报个班系统学习,下面整理的文章都是自己学习后,认为重要的需要弄懂的知识点,做出链接,一方面是为了自己找的话方便,一方 ...

  8. Python全栈开发之路 【第四篇】:Python基础之函数

    本节内容 函数def: 1.位置参数,默认参数 2.位置参数,关键参数 3.如果参数中出现 *users,传递的参数就可以不再是固定的个数, 传过来的所有元素进行打包成元组 *args,**kwarg ...

  9. Python全栈开发之路 【第一篇】:Python 介绍

    本节内容 一.Python介绍 python的创始人为荷兰人——吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本 ...

  10. Python全栈开发之路 【第七篇】:面向对象编程设计与开发(1)

    本节内容 一.编程范式 编程指的是写程序.敲代码,就是指程序员用特定的语法.数据结构和算法编写的代码,目的是来告诉计算机如何执行任务的. 在编程的世界里最常见的两大流派是:面向过程与面向对象.“功夫的 ...

随机推荐

  1. RecyclerView显示列表

    本次要讲的内容是利用RecyclerView显示Users列表的信息,如下图所示. 首先我们来创建模型User.java package com.example.mytest.User; import ...

  2. Pod概述

    Pod的类型 Pod的类型有如下两个: 自主式Pod:自主式Pod的含义简白来说就是不是被控制器管理的Pod,另一种就是被控制管理的Pod,不被控制器管理的Pod你会发现,它一旦死亡的话,就没有人把它 ...

  3. 宏任务&微处理

    事件循环 JavaScript 语言的一大特点就是单线程,同一个时间只能做一件事.为了协调事件.用户交互.脚本.UI 渲染和网络处理等行为,防止主线程的不阻塞,Event Loop 的方案应用而生. ...

  4. .NET应用系统的国际化-基于Roslyn抽取词条、更新代码

    上篇文章我们介绍了 VUE+.NET应用系统的国际化-多语言词条服务 系统国际化改造整体设计思路如下: 提供一个工具,识别前后端代码中的中文,形成多语言词条,按语言.界面.模块统一管理多有的多语言词条 ...

  5. 001-ksum 求符合条件的 k 个数 1. Two Sum/15. 3Sum/18. 4Sum/

    推荐阅读 000-从零开始的数据结构与算法 001-01-ksum 求符合条件的 k 个数 1. Two Sum/15. 3Sum/18. 4Sum/ 002-两数相加 add two numbers ...

  6. sqlmap的基本使用

    sqlmap的基本使用 一.注入 1.查询是否存在注入点 sqlmap -u "http://www.xx.com?id=x" --dbs 检测有哪些数据库 --current-d ...

  7. uniapp安卓离线打包权限问题

    安卓离线打包需要在androidManifest.xml配置 在 manifest 节点下面加上权限(对应uniapp当中manifest.json当中安卓的权限配置),例如: <manifes ...

  8. Unity3D中的Attribute详解(三)

    上一篇我们对系统的Attributes进行了MSIL代码的查看,了解到了其本质就是一个类的构造函数.本章我们将编写自己的Attributes. 首先我们定义书的属性代码,如下: [AttributeU ...

  9. [NotePad++]NotePad++实用技巧

    2 应用技巧 2.1 匹配并捕获/截取 截取第1列的数据 截取前 "(.*)", "(.*)", "(.*)"\)\); 截取后: 2.2 ...

  10. [Windows]CMD命令入门教程 与 Windows常见维护问题

    本博文最早是记录在本地电脑的,由于清理电脑的缘故,顺便将这篇笔记转移到公共博客,以便日后查阅和快速上手使用. 开门见山,步入正题,以下是Windows系统的常用CMD命令. ----2018-03-2 ...