Django 有着强大而又及其易用的admin后台,在这里,你可以轻松实现复杂代码实现的功能,如搜索,筛选,分页,题目可编辑,多选框.
简单到,一行代码就可以实现一个功能,而且模块之间耦合得相当完美.
不信,一起来看看吧!"font-size: large">准备工作
#准备好你的数据库模型思维导图
0.新建一个Django项目,起名为books,并且同时新建一个应用book11
1.首先要设置models模块,根据思维导图,我们知道需要定义3张表,分别是Book,Author,Publisher.
1.1然而,django强大的地方在于,你无需在数据库开辟一张表,ORM的模型,让你只需要关注你要操作的对象.这里用类对象,来替代表,从而使得定义一张数据表Book,就只需要简单的创建Book类对象,即可
#先设计作者Author对象(表)[models.py] "%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_status.short_description="设置所有的书籍为--审核中" set_publisher_dai.short_description="设置所有的书籍为--待出版" set_publisher_del.short_description="设置所有的书籍为--删除"
效果图
调试成功
附上admin.py的全部代码,方便调试不成功的小伙伴
# -*- coding: utf-8 -*- from __future__ import unicode_literals "设置所有的书籍为--已出版" set_publisher_status.short_description="设置所有的书籍为--审核中" set_publisher_dai.short_description="设置所有的书籍为--待出版" set_publisher_del.short_description="设置所有的书籍为--删除" "font-size: large">总结Django真的太强大。。
以上就是本文关于Django admin实现图书管理系统菜鸟级教程完整实例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:
django实现用户登陆功能详解
Python通过Django实现用户注册和邮箱验证功能代码
Python编程django实现同一个ip十分钟内只能注册一次
如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 好薇2024《兵哥哥》1:124K黄金母盘[WAV+CUE]
- 胡歌.2006-珍惜(EP)【步升大风】【FLAC分轨】
- 洪荣宏.2014-拼乎自己看【华特】【WAV+CUE】
- 伊能静.1999-从脆弱到勇敢1987-1996精选2CD【华纳】【WAV+CUE】
- 刘亮鹭《汽车DJ玩主》[WAV+CUE][1.1G]
- 张杰《最接近天堂的地方》天娱传媒[WAV+CUE][1.1G]
- 群星《2022年度发烧天碟》无损黑胶碟 2CD[WAV+CUE][1.4G]
- 罗文1983-罗文甄妮-射雕英雄传(纯银AMCD)[WAV+CUE]
- 群星《亚洲故事香港纯弦》雨果UPMAGCD2024[低速原抓WAV+CUE]
- 群星《经典咏流传》限量1:1母盘直刻[低速原抓WAV+CUE]
- 庾澄庆1993《老实情歌》福茂唱片[WAV+CUE][1G]
- 许巍《在别处》美卡首版[WAV+CUE][1G]
- 林子祥《单手拍掌》华纳香港版[WAV+CUE][1G]
- 郑秀文.1997-我们的主题曲【华纳】【WAV+CUE】
- 群星.2001-生命因爱动听电影原创音乐AVCD【MEDIA】【WAV+CUE】