Django框架快速入门之后台管理admin(书籍管理系统)

一、Django框架介绍

什么是框架?

软件框架就是为实现或完成某种软件开发时,提供了一些基础的软件产品,
框架的功能类似于 基础设施 ,提供并实现最为 基础的软件架构和体系
通常情况下我们依据框架来实现更为复杂的业务程序开发
二个字,框架就是程序的 骨架

Python 中常见的框架有哪些?

大包大揽 Django 被官方称之为完美主义者的Web框架。
力求精简 web.py 和 Tornado
新生代微框架 Flask 和 Bottle

Django 框架介绍

Django 是一个高级的Python Web框架,它鼓励快速开发和清洁,务实的设计。由经验丰富的开发人员构建,它负责Web开发的许多麻烦,因此您可以专注于编写应用程序,而无需重新创建轮子。免费的和开源的。
被官方称之为完美主义者的Web框架。

二、创建第一个Django项目

在线安装Django,指定版本安装
在终端敲

 pip install django==3.1
 django-admin startproject BookManage

创建新项目---->选择Django
在这里插入图片描述
在这里插入图片描述

manage.py :一个命令行工具,可以使你用多种方式对 Django 项目进行交互 内层的目录:项目的真正的Python包
init.py :一个空文件,它告诉Python这个目录应该被看做一个Python包
settings.py :项目的配置
urls.py :项目的URL声明
wsgi.py :项目与 WSGI 兼容的Web服务器入口

三、应用的创建和使用

terminal窗口输入

python manage.py startapp BookApp

路由配置:设置用户访问某个path时执行的函数(业务逻辑)
在bookApp内新建一个urls.py 会更便于管理
在这里插入图片描述

# bookApp/urls.py
from django.conf.urls import url
from django.urls import path
from .views import index
urlpatterns = [
    # 当用户访问bookApp应用的主页时, 执行视图函数index,反向根据名称获取url地址;
    path('', index, name='index'), 

]

随后在 book内编辑urls.py

from django.contrib import admin
from django.urls import path, include
from bookApp.views import index

urlpatterns = [
    path('admin/', admin.site.urls),
    path('book/', include('bookApp.urls')),
    

]

视图函数编写,django所有的视图函数接收请求,返回响应
编辑BookApp/views.py

"""
和视图相关的
"""
from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.
#http://127.0.0.1/login
#http://127.0.0.1/register 根据路由
#http协议:http请求 http响应
def index(request):
    return HttpResponse("westos-1.图书管理系统")

terminal ---->
python manage.py runserver 打开网站逐个访问
在这里插入图片描述

(重点理解)访问过程解析:

浏览器输入 http://127.0.0.1:8000/book 向127.0.0.1的8000端口发起请求,请求path=/book/
Django web服务器的wsgi接收请求, 加载配置文件,读取主路由配置文件book/urls.py
其中内部的include规则找到 bookApp内的urls.py
根据匹配规则找到path=/book/要执行的函数(视图函数)book
执行函数,返回响应并显示在浏览器上

四、项目的数据库模型

ORM对象关系映射

由于开发人员对于sql语句不熟悉,但需要操作,可以通过ORM用面向对象的方式对数据库进行操作。
ORM 对象-关系映射: 用面向对象的方式去操作数据库的创建表以及增删改查等操作

ORM优缺点:
优点:

1.ORM使得我们的通用数据库交互变得简单易行,而且完全不用考虑该死的SQL语句。快速开发,由此而来。
2.可以避免一些新手程序猿写sql语句带来的性能问题。

缺点:

1.性能有所牺牲,不过现在的各种ORM框架都在尝试各种方法,比如缓存,延迟加载登来减轻这个问题。效果很显著。

sqlite数据库建立、导入并管理

编辑 models.py
django框架中,类相当于数据库表,属性相当于数据库的列名称,对象相当于数据库表的一条记录。

"""
数据库相关的文件
"""
from django.db import models

# Create your models here.
"""
ORM: OBJECT RELATIONSHIP MAPPING
通过面向对象的方式对数据库增删改查
SQL:
create table tables values (name, varchar(255),age int);
select * from tablename where xxx=xxx;
import 
update
delete
"""


# 类 数据库的一个表
# 属性 数据库的列名

class Book(models.Model):
    name = models.CharField("书籍名称", max_length=30, unique=True)  # unique=True表示唯一不能重复
    """
    null  是针对数据库而言 null=true 表示数据库该字段可以为空
    blank 是针对表单 如果 等于true 表示表单填写该字段的时候可以不填 一般都一起写
    """
    description = models.CharField("书籍的详细描述", max_length=200, blank=True, null=True)
    publish_date = models.DateField("出版日期", null=True, blank=True)
    sales_count = models.IntegerField("销量", default=0)

    def __str__(self):
        return self.name

    # 自定义对应的表名 默认表明 bookapp_book
    class Meta:
        db_table = 'books'


class Hero(models.Model):
    GENDER_CHOICES = (
        ('1', '男'),
        ('2', '女'),
    )
    name = models.CharField("人物名称", max_length=30)  # unique=True表示唯一不能重复
    gender = models.IntegerField('性别', choices=GENDER_CHOICES)  # 性别在数据库中用整形储存 1-男 2-女
    description = models.CharField("人物的详细描述", max_length=200, blank=True, null=True)
    # 这个人物属于哪本书 book:hero=1:n ===> 外键关联
    # 如果是一对多关系 外键写在多的一端(在这是写在人的一端)
    # book属性是该任务属于哪本书籍,级联删除 当书籍删除时,该书籍的人物也被删除
    book = models.ForeignKey(Book, on_delete=models.CASCADE)

    def __str__(self):
        return self.name

    class Meta:
        db_table = 'heros'

设置setting,激活子应用
在这里插入图片描述

python manage.py makemigrations
	#生成迁移文件

在这里插入图片描述

python manage.py migrate #生成数据表

查看方法:
在右边找到数据库 找到+号 选择数据源 选择SQLIite
在这里插入图片描述
填写名称 在下面的文件 找到db.sqlite3文件后 测试连接 若出现感叹号 只需安装相应插件即可
选择确定即可看到数据库
在这里插入图片描述

在这里插入图片描述

数据库模型基本操作

python manage.py shell 	交互式管理数据库
pip install ipython  shell中可补齐
from BookApp.models import Book,Hero
# 查看所有书籍
Book.objects.all()
b = Book(title = 'booktest')
b.save()
Book.objects.all()

# 查询
b1 = Book.objects.get(id = 1)
b1
b1.title
b1.publish_date
from datetime import date
my_date = date(2021,1,1)
my_date
Book.objects.filter(publish_date__lt=my_date).all() #发布日期小于my_date的书
Book.objects.filter(publish_date__gt=my_date).all() #发布日期大于my_date的书

# 书籍信息修改
b1
b1.publish_date = date(2019,1,2)
b1.save()
b1.pub_date

# 书籍信息的删除
Book.objects.all()
b1.delete()
Book.objects.all()

一对多关系如何去关联

info1= 'lcf'  #描述
info2= 'shin'
hero1 =Hero(name='meeyeon',gender=1,book= Book.objects.get(name='smy')) #添加信息
hero1.description =info1 #添加描述到hero1中
hero1.save() #保存
hero2 =Hero(name='changbeom',gender=0,book= Book.objects.get(name='smy')) 
hero2.description =info2
hero2.save()
Hero.objects.all() #查看
<QuerySet [<Hero: meeyeon>, <Hero: changbeom>]>

b= Book.objects.get(name='smy')
b
<Book: smy>

b.hero_set.all()  #通过书籍对象查找所有人物信息
 <QuerySet [<Hero: meeyeon>, <Hero: changbeom>]>

h= Hero.objects.filter(name='meeyeon').first()
h.book
Out[52]: <Book: smy>

In [53]: h.book.publish_date
Out[53]: datetime.date(2017, 10, 6)

五、admin后台管理
python manage.py createsuperuser # 创建超级管理用户

输入用户名和密码
127.0.0.1:8000/admin 直接访问
在这里插入图片描述

设置语言:
settings.py

LANGUAGE_CODE = 'zh-Hans' 

TIME_ZONE = 'Asia/Shanghai'

在这里插入图片描述

自定义模式加入后台管理

BookApp/admin.py

from django.contrib import admin
# Register your models here.
from  BookApp.models import Book,Hero
admin.site.register(Book)
admin.site.register(Hero)

在这里插入图片描述

中文显示添加模块:

BookApp/models.py, 在每一个需要显示的主类中加入参数

class Meta:
    verbose_name = '图书管理'
    verbose_name_plural = verbose_name #中文无单复数之分,所以两个相等
class Meta:
    verbose_name = '人物管理'
    verbose_name_plural = verbose_name 

更改后结果:
在这里插入图片描述

列表页信息设置修改

BookApp/admin.py

class BookAdmin(admin.ModelAdmin):
    # 列表页可以设置的信息
    # list_display:显示字段,可以点击列头进行排序
    list_display = ['id', 'title', 'pub_date']
    # list_filter:过滤字段,过滤框会出现在右侧
    list_filter = ['title']
    # search_fields:搜索字段,搜索框会出现在上侧
    search_fields = ['title']
    # list_per_page:分页,分页框会出现在下侧
    list_per_page = 10
    # inlines = [HeroInline]


class HeroAdmin(admin.ModelAdmin):
    # 列表页可以设置的信息
    # list_display:显示字段,可以点击列头进行排序
    list_display = ['id', 'name', 'gender', 'hbook']
    # list_filter:过滤字段,过滤框会出现在右侧
    list_filter = ['name', 'hbook']
    # search_fields:搜索字段,搜索框会出现在上侧
    search_fields = ['name']
    # list_per_page:分页,分页框会出现在下侧
    list_per_page = 10

不要忘记调用修改属性的类

BookApp/admin.py

admin.site.register(Book, BookAdmin)
admin.site.register(Hero, HeroAdmin)

fields 修改添加界面属性的先后顺序

BookApp/admin.py

# 添加、修改页属性
# fields:属性的先后顺序
fields = ['name', 'hbook', 'gender', 'content']

关联对象

通常添加一本书以及关联的三个人,通常需要先添加书再添加人
需求:
关联起来,在添加书的时候添加关联的人

BookApp/admin.py

class HeroInline(admin.StackedInline):
#class HeroInline(admin.TabularInline): 两种展示形式
    model = Hero
    extra = 2

在BookAdmin类中添加调用,满足其在添加书籍时最少可添加两个关联的人物

inlines = [HeroInline]

即最终的 admin.py为

from django.contrib import admin

# Register your models here.
from bookApp.models import Book, Hero


#class HeroInline(admin.StackedInline):
class HeroInline(admin.TabularInline):
    model = Hero
    extra = 2


class BookAdmin(admin.ModelAdmin):
    list_display = ['id', 'name', 'publish_date', 'sales_count']
    list_filter = ['publish_date', 'sales_count']
    search_fields = ['name', 'description']
    list_per_page = 10
    inlines = [HeroInline]

class HeroAdmin(admin.ModelAdmin):
    list_display = ['id', 'name', 'gender', 'description']
    list_filter = ['name']
    search_fields = ['name', 'description']
    list_per_page = 10


admin.site.register(Book, BookAdmin)
admin.site.register(Hero, HeroAdmin)

这样,一个简单的图书管理系统后台管理模块就做好了