周末没事自己写了个班级管理系统,虽然简单,但也算个前期学习的总结吧

from django.db import models

# Create your models here.
class Banji(models.Model):
grade = models.CharField(max_length=32,unique=True) class Student(models.Model):
name = models.CharField(max_length=32,unique=True)
banji = models.ForeignKey(to="Banji",on_delete=models.CASCADE) class Teacher(models.Model):
name = models.CharField(max_length=32,unique=True)
banji = models.ManyToManyField("Banji")

models

"""class_crm URL Configuration

The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/1.11/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: url(r'^$', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: url(r'^$', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.conf.urls import url, include
2. Add a URL to urlpatterns: url(r'^blog/', include('blog.urls'))
"""
from django.conf.urls import url
from django.contrib import admin from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
# 班级
url(r'^banji_list/', views.banji_list),
url(r'^add_banji/', views.add_banji),
url(r'^del_banji/', views.del_banji),
url(r'^edit_banji/', views.edit_banji), url(r'^student_list/', views.student_list),
url(r'^add_student/', views.add_student),
url(r'^del_student/', views.del_student),
url(r'^edit_student/', views.edit_student), url(r'^teacher_list/', views.teacher_list),
url(r'^add_teacher/', views.add_teacher),
url(r'^del_teacher/', views.del_teacher),
url(r'^edit_teacher/', views.edit_teacher),
]

urls

from django.shortcuts import render,HttpResponse,redirect
from app01 import models
# Create your views here.
def banji_list(request):
print(111)
banji_list = models.Banji.objects.all().order_by("id")
print(222)
print(banji_list)
return render(request,"banji_list.html",{"banji_list":banji_list}) def add_banji(request):
if request.method == "POST":
name = request.POST.get("new_name")
if not name:
return render(request,"add_banji.html",{"err_name":name,"err_msg":"不能为空"})
add_obj = models.Banji.objects.filter(grade=name)
if add_obj:
return render(request,"add_banji.html",{"err_name":name,"err_msg":"已存在"})
models.Banji.objects.create(grade=name)
return redirect("/banji_list/")
return render(request,"add_banji.html") def del_banji(request):
del_id = request.GET.get("id")
del_list = models.Banji.objects.filter(id=del_id)
del_list.delete()
return redirect("/banji_list/") def edit_banji(request):
edit_id = request.GET.get("id")
edit_obj = models.Banji.objects.get(id=edit_id)
if request.method == "POST":
name = request.POST.get("new_name")
if not name:
return render(request, "edit_banji.html", {"edit_obj": edit_obj,"err_msg":"不能为空"})
mod_obj = models.Banji.objects.filter(grade=name)
if mod_obj:
return render(request, "edit_banji.html", {"edit_obj": edit_obj,"err_msg":"重复了"})
if edit_obj and name and not mod_obj:
edit_obj.grade = name
edit_obj.save()
return redirect("/banji_list/")
if edit_obj:
return render(request,"edit_banji.html",{"edit_obj":edit_obj})
return HttpResponse("不存在!!!") # 学生管理
def student_list(request):
student_list = models.Student.objects.all().order_by("id")
return render(request,"student_list.html",{"student_list":student_list}) def add_student(request):
banji_list = models.Banji.objects.all()
if request.method == "POST":
name = request.POST.get("new_name")
if not name:
return render(request, "add_student.html", {"banji_list": banji_list,"err_name":name,"err_msg":"不能为空"})
add_obj = models.Student.objects.filter(name=name)
if add_obj:
return render(request, "add_student.html", {"banji_list": banji_list,"err_name":name,"err_msg":"此学生已存在"})
banji_id = request.POST.get("banji_id")
models.Student.objects.create(name=name,banji_id=banji_id)
return redirect("/student_list/")
return render(request,"add_student.html",{"banji_list":banji_list}) def del_student(request):
del_id = request.GET.get("id")
del_obj = models.Student.objects.get(id=del_id)
del_obj.delete()
return redirect("/student_list/") def edit_student(request):
edit_id = request.GET.get("id")
edit_obj = models.Student.objects.filter(id=edit_id)
banji_list = models.Banji.objects.all() if request.method == "POST":
name = request.POST.get("new_name")
banji_id = request.POST.get("banji_id")
if not name:
return render(request, "edit_student.html", {"edit_obj": edit_obj, "banji_list": banji_list,"err_msg":"不能为空"})
edit_obj = edit_obj[0]
edit_obj.name = name
edit_obj.banji_id = banji_id
edit_obj.save()
return redirect("/student_list/")
return render(request,"edit_student.html",{"edit_obj":edit_obj[0],"banji_list":banji_list}) def teacher_list(request):
teacher_list = models.Teacher.objects.all()
return render(request,"teacher_list.html",{"teacher_list":teacher_list}) def add_teacher(request):
banji_list = models.Banji.objects.all()
if request.method == "POST":
name = request.POST.get("new_name")
add_obj = models.Teacher.objects.filter(name=name)
if add_obj:
return render(request, "add_teacher.html", {"banji_list": banji_list,"err_name":name,"err_msg":"已存在"})
banji_id = request.POST.getlist("banji_id")
new_tea = models.Teacher.objects.create(name=name)
new_tea.banji.set(banji_id)
return redirect("/teacher_list/")
return render(request,"add_teacher.html",{"banji_list":banji_list}) def del_teacher(request):
del_id = request.GET.get("id")
del_obj = models.Teacher.objects.filter(id=del_id)
del_obj.delete()
return redirect("/teacher_list/") def edit_teacher(request):
edit_id = request.GET.get("id")
edit_obj = models.Teacher.objects.filter(id=edit_id)
banji_list = models.Banji.objects.all()
if request.method == "POST":
name = request.POST.get("new_name")
banji_id = request.POST.getlist("banji_id")
edit_obj = edit_obj[0]
edit_obj.name = name
edit_obj.save()
edit_obj.banji.set(banji_id)
return redirect("/teacher_list/")
return render(request,"edit_teacher.html",{"banji_list":banji_list,"edit_obj":edit_obj[0]})

Views

数据库表关系如下:

总结一些方法:

get为获取单个对象,找不到会报错,所以如果用的话最好try一下

filter获取的是query set集合,也可以理解为对象列表

getlist获取所有

HttpResponse('字符串')   ——》 页面显示字符串的内容
  render(request,'模板的名字',{k1:v1})  ——》 整个HTML文件返回给浏览器
  redirect('/index/')    跳转  重定向  响应头  location:/index/

python终极篇 --- django---班级管理系统的更多相关文章

  1. python 终极篇 --- django 视图系统

    Django的View(视图) 一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受Web请求并且返回Web响应. 响应可以是一张网页的HTML内容,一个重定向,一个404错误, ...

  2. python终极篇 ---django 模板系统

                                                模板系统                                                . MV ...

  3. python 终极篇 ---django 认证

    Django自带的用户认证 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等功能,这还真是个麻烦的事情呢. Djang ...

  4. python 终极篇 --- django 路由系统

                          URL配置                        基本格式: from django.conf.urls import url urlpattern ...

  5. python终极篇 --- django 初识

    1. 下载: 命令行: pip install django==1.11.15 pip install -i 源 django==1.11.15 pycharm settings 解释器 点+号 输入 ...

  6. python web篇 Django centos 命令版

    新建立一个虚拟环境,与其他python 包隔开互不影响 首先新建立一个目录,命名为xx, python3 下操作 $:python -m venv ll_env 注意在有多个Python环境下,使用 ...

  7. python 终极篇 --- form组件 与 modelForm

                                                           form组件                                       ...

  8. python 终极篇 ---- 中间件

    中间件------------------------>>>>>>>>>>>>> 中间件是一个用来处理django的响应与 ...

  9. python 终极篇 cookie与session

    ()cookie与session---------->>>>>>>>>>>>>>>>>>&g ...

随机推荐

  1. WebSocket消息推送(实现进行聊天)和WebSocket简介

    WebSocket简介 WebSocket是HTML5开始提供的一种浏览器与服务器间进行全双工通讯的网络技术.依靠这种技术可以实现客户端和服务器端的长连接,双向实时通信.特点:事件驱动异步使用ws或者 ...

  2. Windows下同时安装Anaconda2与Anaconda3

    1. 安装一个作为主版本,比如先安装Anaconda2,安装时选择[添加path环境变量].我的安装地址为:E:\ProgramData\Anaconda3 2. 安装另一个版本python,安装时注 ...

  3. [luoguP3325][HNOI2012]矿场搭建

    P3225 [HNOI2012]矿场搭建 题目描述 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处.于是矿主决定在某些挖煤 ...

  4. viewpager中 pagerAdapter使用详解

    必须覆盖以下方法instantiateItem(ViewGroup, int) 这个方法,return一个对象,这个对象表明了PagerAdapter适配器选择哪个对象*放在当前的ViewPager中 ...

  5. 重置mysql5.7.25临时密码

    安装完mysql之后,登陆以后,不管运行任何命令,总是提示这个:mac mysql error You must reset your password using ALTER USER statem ...

  6. 车站分级 (2013noip普及组T4)(树形DP)

    题目描述 一条单向的铁路线上,依次有编号为 1,2,…,n 的 n个火车站.每个火车站都有一个级别,最低为 1 级.现有若干趟车次在这条线路上行驶,每一趟都满足如下要求:如果这趟车次停靠了火车站 x ...

  7. Sonar安装-Linux[20171227]

    前言     一款不错的代码质量管理工具Sonar 前期准备     官方参考文档 https://docs.sonarqube.org/display/SONAR/Documentation     ...

  8. 'sessionFactory' or 'hibernateTemplate' is required

    网上都是说在dao中未注入  sessionFactory,然而我有 于是排除 @Autowired public FlightDaoImpl(@Qualifier(value = "ses ...

  9. Vue使用json-server来进行后端数据模拟

    正开发过程中 前后端分离或者不分离 ,接口多半是之后与页面的开发 ,所以建立rest的APL的接口 给前端提供虚拟的数据是非常必要的 所以这里我使用了json-server作为工具,支持CORS和JS ...

  10. HTTP-Http状态码301和302的区别

    官方解释: 301 redirect: 301 代表永久性转移(Permanently Moved) 302 redirect: 302 代表暂时性转移(Temporarily Moved ) 共同点 ...