基于python的图书管理系统测试步骤_Django admin实现图书管理系统菜鸟级教程完整实例...
Django 有着强大而又及其易用的admin后台,在这里,你可以轻松实现复杂代码实现的功能,如搜索,筛选,分页,题目可编辑,多选框.
简单到,一行代码就可以实现一个功能,而且模块之间耦合得相当完美.
不信,一起来看看吧!?用Django实现管理书籍的系统,并能在前台界面对书籍进行增删查改,筛选,分页,以及批量查询修改功能.
准备工作
#准备好你的数据库模型思维导图
0.新建一个Django项目,起名为books,并且同时新建一个应用book11
1.首先要设置models模块,根据思维导图,我们知道需要定义3张表,分别是Book,Author,Publisher.
1.1然而,django强大的地方在于,你无需在数据库开辟一张表,ORM的模型,让你只需要关注你要操作的对象.这里用类对象,来替代表,从而使得定义一张数据表Book,就只需要简单的创建Book类对象,即可
#先设计作者Author对象(表)[models.py]
class Author(models.Model): #继承于models.Model这个父类,从而实现多态
first_name=models.CharField(max_length=32) #名字的字段,使用字符串格式,最大长度32
last_name=models.CharField(max_length=32)
email=models.EmailField() #email字段,使用email自带的格式
def __unicode__(self): #定义unicode函数,是为了让对象在实例化的时候,可以返回打印输出它的名字<阿文>.不至于显示为<** object>
return "%s--%s"%(self.first_name,self.last_name)
#出版社
class Publisher(models.Model):
name=models.CharField(max_length=64,unique=True) #出版社名称,唯一,是主键
address=models.CharField(max_length=64,unique=True)
city=models.CharField(max_length=32)
state_province=models.CharField(max_length=32)
country=models.CharField(max_length=32)
website=models.URLField() #主页,采用自带的url格式
def __unicode__(self):
return "%s"%(self.name)
#定义一个选项,里面包含3个可选框,用以下面的书籍表publisher_state下拉选择
STATUS_CHOICES=(
('checkout',u'已出版'),
('dai',u'待出版'),
('status',u'审核中'),
)
#书籍表
class Book(models.Model):
name=models.CharField(max_length=64)
authors=models.ManyToManyField(Author) #作者,多对多的关系
publisher=models.ForeignKey(Publisher) #出版社,外键管理到Publisher表
publisher_date=models.DateField(auto_now_add=True)
publisher_state=models.CharField(max_length=20,choices=STATUS_CHOICES,default='checkout') #出版状态,是一个可选框
def __unicode__(self):
return "%s--%s"%(self.name,self.publisher_date)
完整的代码:
1.2然后,创建完models后,一定要创建映射文件,并且映射到数据库,否则数据库是不存在的
python manage.py makemigrations
python manage.py migrate
2.调试shell的models模块,使用对象操作增删查改
##进入shell 模式
python manage.py shell
##导入Publisher对象
from book11.models import Publisher
##查询id=1的queryset赋值给p
p=Publisher.objects.get(id=1)
#对的对象进行操作,修改city="changsha",等价于[Publisher.objects.filter(id=1).update(city='changsha')]操作.
p.city='changsha'
#需要提交保存,否则不生效
p.save()
前后对比,操作数据库字段就像操作对象一样简单!这便是ORM的优势
3.增加一个admin用户
G:\git\web\books>python manage.py createsuperuser #增加一个超级用户
Username (leave blank to use 'huan5'): admin #用户名
Email address: admin@qq.com #邮箱
Password: #输8位密码2次
Password (again):
Superuser created successfully.
4.编辑admin.py
4.1将models导入,并且注册网站的Author,Publisher,Boos模块
#设置默认编码符
# -*- coding: utf-8 -*-
from book11 import models #导入数据库
admin.site.register(models.Author)
admin.site.register(models.Publisher)
admin.site.register(models.Book)
#启动服务
python manage.py runserver 0.0.0.0:8086
#并打开浏览器执行
http://127.0.0.1:8086
书名已经成功显示出来
4.2配置一些扩展功能
from book11 import models
# 创建一个Bookadmin的modeladmin的子类
class Bookadmin(admin.ModelAdmin):
list_display=('id','name','publisher','publisher_date','publisher_state')
search_fields=('name',)
list_filter=('publisher','publisher_date',)
list_per_page=5
list_editable=('name','publisher_state',)
list_select_related=('publisher',)
filter_horizontal=('authors',)
raw_id_fields=('publisher',)
actions=['set_publisher_checkout','set_publisher_dai','set_publisher_status','set_publisher_del',]
admin.site.register(models.Author,Authoradmin) #不要忘了把这些定义好的扩展写进来
admin.site.register(models.Publisher,Publisheradmin)
admin.site.register(models.Book,Bookadmin)
#配置作者页面的扩展内容
class Authoradmin(admin.ModelAdmin):
list_display=('first_name','last_name','email')
#配置出版社的扩展显示
class Publisheradmin(admin.ModelAdmin):
list_display = ('name','address','country',)
4.3为了批量操作,我们给他增加了actions,定义如下
def set_publisher_checkout(modeladmin,request,queryset):
selected=request.POST.getlist(admin.ACTION_CHECKBOX_NAME) #选中传入的表单中,勾选的checkbox对应的id集合
models.Book.objects.filter(id__in=selected).update(publisher_state='checkout') #将所有选中的id对象,修改出版状态为checkout
def set_publisher_dai(modeladmin,request,queryset):
selected=request.POST.getlist(admin.ACTION_CHECKBOX_NAME)
models.Book.objects.filter(id__in=selected).update(publisher_state='dai')
def set_publisher_status(modeladmin,request,queryset):
selected=request.POST.getlist(admin.ACTION_CHECKBOX_NAME)
models.Book.objects.filter(id__in=selected).update(publisher_state='status')
def set_publisher_del(modeladmin,request,queryset): #########扩展部分,增加对选中的记录今夕删除!###########
selected=request.POST.getlist(admin.ACTION_CHECKBOX_NAME)
models.Book.objects.filter(id__in=selected).delete()
set_publisher_checkout.short_description="设置所有的书籍为--已出版" #为了使界面更加友好,添加别名
set_publisher_status.short_description="设置所有的书籍为--审核中"
set_publisher_dai.short_description="设置所有的书籍为--待出版"
set_publisher_del.short_description="设置所有的书籍为--删除"
效果图
调试成功
附上admin.py的全部代码,方便调试不成功的小伙伴
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.contrib import admin
from book11 import models
# Register your models here.
class Bookadmin(admin.ModelAdmin):
list_display=('id','name','publisher','publisher_date','publisher_state')
search_fields=('name',)
list_filter=('publisher','publisher_date',)
list_per_page=5
list_editable=('name','publisher_state',)
list_select_related=('publisher',)
filter_horizontal=('authors',)
raw_id_fields=('publisher',)
actions=['set_publisher_checkout','set_publisher_dai','set_publisher_status','set_publisher_del',]
def set_publisher_checkout(modeladmin,request,queryset):
selected=request.POST.getlist(admin.ACTION_CHECKBOX_NAME)
models.Book.objects.filter(id__in=selected).update(publisher_state='checkout')
def set_publisher_dai(modeladmin,request,queryset):
selected=request.POST.getlist(admin.ACTION_CHECKBOX_NAME)
models.Book.objects.filter(id__in=selected).update(publisher_state='dai')
def set_publisher_status(modeladmin,request,queryset):
selected=request.POST.getlist(admin.ACTION_CHECKBOX_NAME)
models.Book.objects.filter(id__in=selected).update(publisher_state='status')
def set_publisher_del(modeladmin,request,queryset):
selected=request.POST.getlist(admin.ACTION_CHECKBOX_NAME)
models.Book.objects.filter(id__in=selected).delete()
set_publisher_checkout.short_description="设置所有的书籍为--已出版"
set_publisher_status.short_description="设置所有的书籍为--审核中"
set_publisher_dai.short_description="设置所有的书籍为--待出版"
set_publisher_del.short_description="设置所有的书籍为--删除"
class Authoradmin(admin.ModelAdmin):
list_display=('first_name','last_name','email')
class Publisheradmin(admin.ModelAdmin):
list_display = ('name','address','country',)
admin.site.register(models.Author,Authoradmin)
admin.site.register(models.Publisher,Publisheradmin)
admin.site.register(models.Book,Bookadmin)
不禁感叹再也没有比django更加简单好用,容易操作的后台了.
总结
Django真的太强大。。
以上就是本文关于Django admin实现图书管理系统菜鸟级教程完整实例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:
django实现用户登陆功能详解
Python通过Django实现用户注册和邮箱验证功能代码
Python编程django实现同一个ip十分钟内只能注册一次
如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
本文标题: Django admin实现图书管理系统菜鸟级教程完整实例
本文地址: http://www.cppcns.com/jiaoben/python/214183.html
基于python的图书管理系统测试步骤_Django admin实现图书管理系统菜鸟级教程完整实例...相关推荐
- py225基于python的家政管理系统设计
开发环境 项目编号: py225基于python的家政管理系统设计 开发语言:Python python框架:django 软件版本:python3.7/python3.8 数据库:mysql 5.7 ...
- 用python设计学生管理系统_基于python和tkinter实现的一个简单的学生信息管理系统...
一个简单的学生信息管理系统基于python和tkinter 1.需求分析1.大学生信息管理系统使用tkinter接口创建一个窗口.使界面更漂亮.2. 实现与数据库的连接,教师和学生的信息可以保存或读取 ...
- c语言程序设计图书管理,C语言程序设计报告 图书馆信息管理系统
C语言程序设计报告 图书馆信息管理系统 2011 年第二阶段课程设计成果报告实训项目: 程序设计技术课程设计 学号: 0112959 姓名: 张麦华 专业: 信息管理与信息系统 实训日期:2011 年 ...
- 基于python和MySQL数据库开发应用程序:学生信息成绩管理系统1.0版本
目录: 前言 一,需求分析 二,前期准备 三,编写代码 1.app.py 2.__init__.py 3.models.py 四,功能描述 1.界面展示 2.系统流程图介绍 3.功能介绍 系统优缺点 ...
- python图书管理实训报告总结_图书管理系统心得-总结报告模板
图书管理系统心得 为期两个星期的 c# 图书管理系统实习终于结束了,总算松了一口气,在这 短短的两周时间内承受了很大的压力现在终于能够得到"释放"了, 感觉到很轻 松. 回顾这两周 ...
- python图书管理实训报告总结_图书管理系统实验报告
图书管理系统实验报告 一.问题描述 有一个小型书库保管了大量图书,关于图书有大量信息需要处理,这些信息包 括图书的分类.书名.作者名.购买日期.价格等.现要求编写一个程序以便于对 图书的管理. 基本要 ...
- 基于python的密码管理工具
如何记住各种各样的账户名和密码? 这是一个头疼的问题. 现在各种社区,商业网站,客户端app,全都使用 用户名+密码 或 邮箱+密码的登陆方式.当你使用了越来越多的服务,就意味着你要管理越来越多的账户 ...
- 基于python的论文摘要怎么写_Django显示文章摘要需要如何写
需要在blog主页显示文章的摘要, 即显示文章的前面一部分. 在django中, 我尝试过以下做法: article|safe|truncatechars:100 // 截取文章的前100个单词 但问 ...
- 基于python的药店管理系统软件_一套很不错的药店管理软件,值得一看
药店管理系统0.00 B30-08-03|10:51 594.00 B01-11-04|16:34 my30.00 B30-08-03|10:51 ehlib210.00 B10-04-03|17:1 ...
最新文章
- 官方 | Keras分布式训练教程
- Python 进阶 — 创建本地 PyPI 仓库与 Python 程序的离线部署
- 夺命雷公狗---linux NO:22 linux下的yum安装的高级配置
- Spring SpringMVC SpringBoot SpringCloud概念、关系及区别
- Ubuntu 12.04下安装GTK 2.24.10
- 【模拟】Codeforces 710C Magic Odd Square
- 谈表达式树的缓存(7):五种缓存方式的总体分析及改进方案
- Ubuntu在vmware虚拟机无法上网的解决方法
- stats | 概率分布与随机数生成(一)——离散型分布
- 字节跳动 Byte Camp 冬令营报名启动,高质量赛题带你线下备战 ICPC
- Perl调用shell命令方法小结
- linux+vi+注掉代码,VI编辑器之删除操作(示例代码)
- dubbo k8s 服务发现_Dubbo-go 发布 1.5 版,朝云原生迈出关键一步
- AD原理图库和PCB封装库下载
- 基于JavaWeb的高校试题库管理系统设计与实现 毕业论文+项目源码及数据库文件、
- 阿里图标库的使用方式
- 摄影构图学83年绝版_常用的摄影构图之点线面
- 2018-2019赛季多校联合新生训练赛第四场题解与补题(中石油)
- 手把手带你学python自动化测试(一)——自动化测试环境搭建
- 字节跳动资深面试官亲述:面试应该注意哪些问题?
热门文章
- CC++中的qsort库函数
- scan-cvs-user.sh
- 【JavaScript学习】JavaScript对象创建
- 艾伟:WCF从理论到实践(2):决战紫禁之巅
- Linux Software RAID的rebuild速度。
- c#字符型转化为asc_C#字符串和ASCII码的转换
- Android studio gradle 无法获取 pom文件
- excel range 判断日期型_为什么精英都是Excel控?
- redis 值字符串前面部分乱码_redis key乱码
- chunk_split_PHP chunk_split()函数与示例