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实现图书管理系统菜鸟级教程完整实例...相关推荐

  1. py225基于python的家政管理系统设计

    开发环境 项目编号: py225基于python的家政管理系统设计 开发语言:Python python框架:django 软件版本:python3.7/python3.8 数据库:mysql 5.7 ...

  2. 用python设计学生管理系统_基于python和tkinter实现的一个简单的学生信息管理系统...

    一个简单的学生信息管理系统基于python和tkinter 1.需求分析1.大学生信息管理系统使用tkinter接口创建一个窗口.使界面更漂亮.2. 实现与数据库的连接,教师和学生的信息可以保存或读取 ...

  3. c语言程序设计图书管理,C语言程序设计报告 图书馆信息管理系统

    C语言程序设计报告 图书馆信息管理系统 2011 年第二阶段课程设计成果报告实训项目: 程序设计技术课程设计 学号: 0112959 姓名: 张麦华 专业: 信息管理与信息系统 实训日期:2011 年 ...

  4. 基于python和MySQL数据库开发应用程序:学生信息成绩管理系统1.0版本

    目录: 前言 一,需求分析 二,前期准备 三,编写代码 1.app.py 2.__init__.py 3.models.py 四,功能描述 1.界面展示 2.系统流程图介绍 3.功能介绍 系统优缺点 ...

  5. python图书管理实训报告总结_图书管理系统心得-总结报告模板

    图书管理系统心得 为期两个星期的 c# 图书管理系统实习终于结束了,总算松了一口气,在这 短短的两周时间内承受了很大的压力现在终于能够得到"释放"了, 感觉到很轻 松. 回顾这两周 ...

  6. python图书管理实训报告总结_图书管理系统实验报告

    图书管理系统实验报告 一.问题描述 有一个小型书库保管了大量图书,关于图书有大量信息需要处理,这些信息包 括图书的分类.书名.作者名.购买日期.价格等.现要求编写一个程序以便于对 图书的管理. 基本要 ...

  7. 基于python的密码管理工具

    如何记住各种各样的账户名和密码? 这是一个头疼的问题. 现在各种社区,商业网站,客户端app,全都使用 用户名+密码 或 邮箱+密码的登陆方式.当你使用了越来越多的服务,就意味着你要管理越来越多的账户 ...

  8. 基于python的论文摘要怎么写_Django显示文章摘要需要如何写

    需要在blog主页显示文章的摘要, 即显示文章的前面一部分. 在django中, 我尝试过以下做法: article|safe|truncatechars:100 // 截取文章的前100个单词 但问 ...

  9. 基于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 ...

最新文章

  1. 官方 | Keras分布式训练教程
  2. Python 进阶 — 创建本地 PyPI 仓库与 Python 程序的离线部署
  3. 夺命雷公狗---linux NO:22 linux下的yum安装的高级配置
  4. Spring SpringMVC SpringBoot SpringCloud概念、关系及区别
  5. Ubuntu 12.04下安装GTK 2.24.10
  6. 【模拟】Codeforces 710C Magic Odd Square
  7. 谈表达式树的缓存(7):五种缓存方式的总体分析及改进方案
  8. Ubuntu在vmware虚拟机无法上网的解决方法
  9. stats | 概率分布与随机数生成(一)——离散型分布
  10. 字节跳动 Byte Camp 冬令营报名启动,高质量赛题带你线下备战 ICPC
  11. Perl调用shell命令方法小结
  12. linux+vi+注掉代码,VI编辑器之删除操作(示例代码)
  13. dubbo k8s 服务发现_Dubbo-go 发布 1.5 版,朝云原生迈出关键一步
  14. AD原理图库和PCB封装库下载
  15. 基于JavaWeb的高校试题库管理系统设计与实现 毕业论文+项目源码及数据库文件、
  16. 阿里图标库的使用方式
  17. 摄影构图学83年绝版_常用的摄影构图之点线面
  18. 2018-2019赛季多校联合新生训练赛第四场题解与补题(中石油)
  19. 手把手带你学python自动化测试(一)——自动化测试环境搭建
  20. 字节跳动资深面试官亲述:面试应该注意哪些问题?

热门文章

  1. CC++中的qsort库函数
  2. scan-cvs-user.sh
  3. 【JavaScript学习】JavaScript对象创建
  4. 艾伟:WCF从理论到实践(2):决战紫禁之巅
  5. Linux Software RAID的rebuild速度。
  6. c#字符型转化为asc_C#字符串和ASCII码的转换
  7. Android studio gradle 无法获取 pom文件
  8. excel range 判断日期型_为什么精英都是Excel控?
  9. redis 值字符串前面部分乱码_redis key乱码
  10. chunk_split_PHP chunk_split()函数与示例