100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > Django框架快速入门之后台管理admin(书籍管理系统)

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

时间:2018-10-19 04:57:40

相关推荐

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

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

一、Django框架介绍

什么是框架?

软件框架就是为实现或完成某种软件开发时,提供了一些基础的软件产品,

框架的功能类似于 基础设施 ,提供并实现最为 基础的软件架构和体系

通常情况下我们依据框架来实现更为复杂的业务程序开发

二个字,框架就是程序的 骨架

Python 中常见的框架有哪些?

大包大揽 Django 被官方称之为完美主义者的Web框架。

力求精简 web.py 和 Tornado

新生代微框架 Flask 和 Bottle

Django 框架介绍

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

被官方称之为完美主义者的Web框架。

二、创建第一个Django项目

在线安装Django,指定版本安装

在终端敲

pip install django==3.1django-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.pyfrom django.conf.urls import urlfrom django.urls import pathfrom .views import indexurlpatterns = [# 当用户访问bookApp应用的主页时, 执行视图函数index,反向根据名称获取url地址;path('', index, name='index'), ]

随后在 book内编辑urls.py

from django.contrib import adminfrom django.urls import path, includefrom bookApp.views import indexurlpatterns = [path('admin/', admin.site.urls),path('book/', include('bookApp.urls')),]

视图函数编写,django所有的视图函数接收请求,返回响应

编辑BookApp/views.py

"""和视图相关的"""from django.shortcuts import renderfrom 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 updatedelete"""# 类 数据库的一个表# 属性 数据库的列名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_bookclass 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.nameclass 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)b1b1.titleb1.publish_datefrom datetime import datemy_date = date(,1,1)my_dateBook.objects.filter(publish_date__lt=my_date).all() #发布日期小于my_date的书Book.objects.filter(publish_date__gt=my_date).all() #发布日期大于my_date的书# 书籍信息修改b1b1.publish_date = date(,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 =info2hero2.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.bookOut[52]: <Book: smy>In [53]: h.book.publish_dateOut[53]: datetime.date(, 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,Heroadmin.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 = Heroextra = 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 = Heroextra = 2class BookAdmin(admin.ModelAdmin):list_display = ['id', 'name', 'publish_date', 'sales_count']list_filter = ['publish_date', 'sales_count']search_fields = ['name', 'description']list_per_page = 10inlines = [HeroInline]class HeroAdmin(admin.ModelAdmin):list_display = ['id', 'name', 'gender', 'description']list_filter = ['name']search_fields = ['name', 'description']list_per_page = 10admin.site.register(Book, BookAdmin)admin.site.register(Hero, HeroAdmin)

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。