1、Django_admin组件的意义

作者:Eric
微信:loveoracle11g

新建Django项目bms图书管理系统

App为book

book/models.py添加表关系

from django.db import models

# Create your models here.

class Author(models.Model):
    nid = models.AutoField(primary_key=True)
    name = models.CharField(max_length=32)
    age = models.IntegerField()

class Publish(models.Model):
    nid = models.AutoField(primary_key=True)
    name = models.CharField(max_length=32)
    city = models.CharField(max_length=32)
    email = models.EmailField()

class Book(models.Model):
    nid = models.AutoField(primary_key=True)
    title = models.CharField(max_length=32)
    publishDate = models.DateField()
    price = models.DecimalField(max_digits=5, decimal_places=2)
    # 与Publish表建立一对多的关系,外键字段建立在多的一方
    publish = models.ForeignKey(to="Publish", to_field="nid", on_delete=models.CASCADE)
    # 与Author表建立多对多的关系,ManyToManyField可以建在两个模型中的任意一个,自动创建第三张表
    authors = models.ManyToManyField(to="Author",)

敲两条命令迁移数据

F:\深圳骑士计划\crm\bms>python manage.py makemigrations
Migrations for 'book':
  book\migrations\0001_initial.py
    - Create model Author
    - Create model AuthorDetail
    - Create model Book
    - Create model Publish
    - Add field publish to book
    - Add field authorDetail to author

F:\深圳骑士计划\crm\bms>python manage.py migrate
Operations to perform:
  Apply all migrations: admin, auth, book, contenttypes, sessions
Running migrations:
  Applying contenttypes.0001_initial... OK
  Applying auth.0001_initial... OK
  Applying admin.0001_initial... OK
  Applying admin.0002_logentry_remove_auto_add... OK
  Applying admin.0003_logentry_add_action_flag_choices... OK
  Applying contenttypes.0002_remove_content_type_name... OK
  Applying auth.0002_alter_permission_name_max_length... OK
  Applying auth.0003_alter_user_email_max_length... OK
  Applying auth.0004_alter_user_username_opts... OK
  Applying auth.0005_alter_user_last_login_null... OK
  Applying auth.0006_require_contenttypes_0002... OK
  Applying auth.0007_alter_validators_add_error_messages... OK
  Applying auth.0008_alter_user_username_max_length... OK
  Applying auth.0009_alter_user_last_name_max_length... OK
  Applying book.0001_initial... OK
  Applying sessions.0001_initial... OK

多出了一个db.sqlite3文件

http://127.0.0.1:8000/admin

它给我跳转到登录界面了,它里面用的是redirect

打开Run manage.py Task

输入命令创建超级用户

manage.py@bms > createsuperuser
输入用户名:yuan
邮箱:不写
输入密码:yuan1234
再次输入密码:yuan1234
manage.py@bms > createsuperuser
"D:\Pycharm\PyCharm 2018.3.2\bin\runnerw64.exe" C:\Python36\python.exe "D:\Pycharm\PyCharm 2018.3.2\helpers\pycharm\django_manage.py" createsuperuser F:/深圳骑士计划/crm/bms
Tracking file by folder pattern:  migrations
Username (leave blank to use 'zhouwanchun'):  yuan
Email address:
Warning: Password input may be echoed.
Password:  yuan1234
Warning: Password input may be echoed.
Password (again):  yuan1234
Superuser created successfully.

那我们就可以登录了

在book/admin.py

from django.contrib import admin

# Register your models here.

# from .models import Book, Publish, Author
from book.models import Book, Publish, Author

admin.site.register(Book)
admin.site.register(Publish)
admin.site.register(Author)

接下来项目重启,刷新浏览器

BOOK就是App应用

下面有三张表Authors、Books、Publishs

点击Publishs表,里面什么都没有,可以自己添加数据行,点击ADD PUBLISH

在book/models.py里面的class Publish下面添加

    def __str__(self):
        return self.name

再来添加出版社

回到 http://127.0.0.1:8000/admin/

点击 Publishs

再随便点击一个出版社,比如橘子出版社,发现有删除功能了

点击Delete,然后Yes I'm sure.  把这个橘子出版社就删除了。

看文件数据库这边跟着同步信息了

我们再把 橘子出版社 添加过来

回到首页 http://127.0.0.1:8000/admin/

点击 Authors表,添加ADD AUTHOR

在book/models.py里面的class Author下面添加

    def __str__(self):
        return self.name

再来添加一个作者,太白 20岁

点击Alex,可以删除,可以修改,那我们修改Alex为35岁

回到首页 http://127.0.0.1:8000/admin/

点击Books, 添加ADD BOOK

在book/models.py里面的class Book下面添加

    def __str__(self):
        return self.title

再添加一个书籍《三国演义》,但是我想让它加入到西瓜出版社,可以直接创建西瓜出版社

再来添加一本书籍《金瓶煤》

在book/admin.py添加修改

from django.contrib import admin

# Register your models here.

# from .models import Book, Publish, Author
from book.models import Book, Publish, Author

class BookConfig(admin.ModelAdmin):
    list_display = ["title", "publishDate", "price", "publish"]

admin.site.register(Book, BookConfig) # 意思是你展示Book时要听BookConfig的
admin.site.register(Publish)
admin.site.register(Author)

重启项目,刷新浏览器

这里还有一个批量删除功能

2、Django_admin组件的自定制列

我们再来创建一个App
manage.py@bms > startapp app01

项目配置文件注册

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'book.apps.BookConfig',
    'app01',
]

在app01/models.py里写

from django.db import models

# Create your models here.

class Host(models.Model):
    name = models.CharField(max_length=32)

然后迁移数据

F:\深圳骑士计划\crm\bms>python manage.py makemigrations
Migrations for 'app01':
  app01\migrations\0001_initial.py
    - Create model Host

F:\深圳骑士计划\crm\bms>python manage.py migrate
Operations to perform:
  Apply all migrations: admin, app01, auth, book, contenttypes, sessions
Running migrations:
  Applying app01.0001_initial... OK

在app01/admin.py里面写

from django.contrib import admin

# Register your models here.
from .models import Host

admin.site.register(Host)

然后重启项目,浏览器访问项目首页

查看页面:http://127.0.0.1:8000/admin/app01/host/
添加页面:http://127.0.0.1:8000/admin/app01/host/add/
编辑页面:http://127.0.0.1:8000/admin/app01/host/1/change/    host后面数字1不固定
编辑页面:http://127.0.0.1:8000/admin/app01/host/2/change/
删除页面:http://127.0.0.1:8000/admin/app01/host/2/delete/

在book/admin.py里写,自定制显示列

from django.contrib import admin

# Register your models here.

# from .models import Book, Publish, Author
from book.models import Book, Publish, Author

class BookConfig(admin.ModelAdmin):
    list_display = ["title", "publishDate", "price", "publish"]

class PublishConfig(admin.ModelAdmin):
    list_display = ["name", "city", "email"]

admin.site.register(Book, BookConfig) # 意思是你展示Book时要听BookConfig的
admin.site.register(Publish, PublishConfig)
admin.site.register(Author)

重启项目,浏览器访问 http://127.0.0.1:8000/admin/book/publish/

自定制显示列,多对多

from django.contrib import admin

# Register your models here.

# from .models import Book, Publish, Author
from book.models import Book, Publish, Author

class BookConfig(admin.ModelAdmin):
    # 自定制显示列
    def show_authors(self, obj):
        return " , ".join([obj.name for obj in obj.authors.all()])

    list_display = ["title", "publishDate", "price", "publish", "show_authors"]

class PublishConfig(admin.ModelAdmin):
    list_display = ["name", "city", "email"]

admin.site.register(Book, BookConfig) # 意思是你展示Book时要听BookConfig的
admin.site.register(Publish, PublishConfig)
admin.site.register(Author)

重启项目,浏览器访问: http://127.0.0.1:8000/admin/book/book

在book/models.py里面的class Book添加修改

class Book(models.Model):
    nid = models.AutoField(primary_key=True)
    title = models.CharField(max_length=32)
    publishDate = models.DateField()
    price = models.DecimalField(max_digits=5, decimal_places=2)
    state = models.IntegerField(choices=[(1, "已出版"), (0, "未出版")], default=1)

    # 与Publish表建立一对一的关系,外键字段建立在多的一方
    publish = models.ForeignKey(to="Publish", to_field="nid", on_delete=models.CASCADE)
    # 与Author表建立多对多的关系,ManyToManyField可以建在两个模型中的任意一个,自动创建第三张表
    authors = models.ManyToManyField(to="Author",)

    def __str__(self):
        return self.title

执行数据迁移

manage.py@bms > makemigrations
manage.py@bms > migrate

在book/admin.py里添加修改class BookConfig

class BookConfig(admin.ModelAdmin):
    # 自定制显示列
    def show_authors(self, obj):
        return " , ".join([obj.name for obj in obj.authors.all()])

    list_display = ["title", "publishDate", "price", "publish", "show_authors", "state"]

重启项目,浏览器刷新访问

嘿!它自己给我展示出来了"已出版",现在我就想让它展示数据库里面存的那个值

在book/admin.py里面添加修改

class BookConfig(admin.ModelAdmin):
    # 自定制显示列
    def show_authors(self, obj):
        return " , ".join([obj.name for obj in obj.authors.all()])

    def show_state(self, obj):
        return obj.state

    list_display = ["title", "publishDate", "price", "publish", "show_authors", "state", "show_state"]

重启项目,刷新浏览器访问

你要是这样写的话

    def show_state(self, obj):
        # return obj.state
        return obj.get_state_display()

是不是和左边的state显示一样了呀

3、Django_admin组件的其他功能

我们设备按着日期时间超链接

class BookConfig(admin.ModelAdmin):
    # 自定制显示列
    def show_authors(self, obj):
        return " , ".join([obj.name for obj in obj.authors.all()])

    def show_state(self, obj):
        # return obj.state
        return obj.get_state_display()

    list_display = ["title", "publishDate", "price", "publish", "show_authors", "state", "show_state"]
    list_display_links = ["publishDate",]

重启项目,刷新浏览器

想加几个加几个超链接

    list_display = ["title", "publishDate", "price", "publish", "show_authors", "state", "show_state"]
    list_display_links = ["title", "publishDate"]

重启项目,刷新浏览器

添加搜索框功能

    list_display = ["title", "publishDate", "price", "publish", "show_authors", "state", "show_state"]
    list_display_links = ["title", "publishDate"]
    search_fields = ["title"]

搜索三国,看三国演义出来了吧。

批量处理功能

    list_display = ["title", "publishDate", "price", "publish", "show_authors", "state", "show_state"]
    list_display_links = ["title", "publishDate"]
    search_fields = ["title"]
    # action操作
    def patch_init(self, request, queryset):
        print("OK")
    patch_init.short_description = "批量处理"  # 起个中文名字
    actions = [patch_init]

批量处理书籍的价格

    # action操作
    def patch_init(self, request, queryset):
        print("OK")
        queryset.update(price=0)
    patch_init.short_description = "价格初始化为0元"  # 起个中文名字
    actions = [patch_init]

多级过滤框

    list_filter = ["publish"]

它是可以放多对多字段的
    list_filter = ["publish", "authors"]

排序,按照书籍的价格,首先你要编辑所有书籍的价格,因为刚才价格重置为0了

    ordering = ["price"]  # 默认升序

    ordering = ["-price"]  # 降序排列

    ordering = ["-price", "-nid"]  # 如果价格一样,可以按照id排列
    change_list_template = "index.html"  # 以后前端工程师写好了网页,你拿过来放在templates目录里直接用就行了。现在Django用的自己html文件

本节课内容写完

Django_admin组件的更多相关文章

  1. Django学习---Form组件认证

    Form组件认证 能够帮助我们做用户认证. 以前写我们自己写用户认证的时候,我们自己写HTML的form表单,点击提交,数据就被发送到后台,后台进行验证.在验证过程中我们就需要自己去写正则表达式去匹配 ...

  2. ExtJS 4.2 评分组件

    上一文章是扩展ExtJS自带的Date组件.在这里将创建一个评分组件. 目录 1. 介绍 2. 示例 3. 资源下载 1. 介绍 代码参考的是 Sencha Touch 2上的一个RatingStar ...

  3. react组件的生命周期

    写在前面: 阅读了多遍文章之后,自己总结了一个.一遍加强记忆,和日后回顾. 一.实例化(初始化) var Button = React.createClass({ getInitialState: f ...

  4. react-router 组件式配置与对象式配置小区别

    1. react-router 对象式配置 和 组件式配置    组件式配置(Redirect) ----对应---- 对象式配置(onEnter钩子) IndexRedirect -----对应-- ...

  5. Angular2入门系列教程3-多个组件,主从关系

    上一篇 Angular2项目初体验-编写自己的第一个组件 好了,前面简单介绍了Angular2的基本开发,并且写了一个非常简单的组件,这篇文章我们将要学会编写多个组件并且有主从关系 现在,假设我们要做 ...

  6. Angular2入门系列教程2-项目初体验-编写自己的第一个组件

    上一篇 使用Angular-cli搭建Angular2开发环境 Angular2采用组件的编写模式,或者说,Angular2必须使用组件编写,没有组件,你甚至不能将Angular2项目启动起来 紧接着 ...

  7. .NET Core 首例 Office 开源跨平台组件(NPOI Core)

    前言 最近项目中,需要使用到 Excel 导出,找了一圈发现没有适用于 .NET Core的,不依赖Office和操作系统限制的 Office 组件,于是萌生了把 NPOI 适配并移植到 .NET C ...

  8. .NetCore中的日志(1)日志组件解析

    .NetCore中的日志(1)日志组件解析 0x00 问题的产生 日志记录功能在开发中很常用,可以记录程序运行的细节,也可以记录用户的行为.在之前开发时我一般都是用自己写的小工具来记录日志,输出目标包 ...

  9. BootStrap_02之全局样式及组件

    1.BootStrap指定的四种屏幕尺寸: ①超大PC屏幕--lg(large):w>=1200px: ②中等PC屏幕--md(medium):1200px>w>=992px: ③P ...

随机推荐

  1. 简述采用四次握手机制释放TCP连接的四个步骤

    (1)源结点A向目的结点B发送连接释放请求(FIN,seg=x),并且不再向B发送数据,但仍继续接收从B发来的数据. (2)目的结点B收到此连接释放请求后立即向A发出确认(ACK,ack=x+1),但 ...

  2. 微信小程序城市定位(百度地图API)

    概述 微信小程序提供一些API(地址)用于获取当前用户的地理位置等信息,但无论是wx.getLocation,还是wx.chooseLocation均没有单独的字段表示国家与城市信息,仅有经纬度信息. ...

  3. Python3+pyshark捕获数据包并保存为文件

    一.直接使用wireshark捕获数据包并保存为文件 可以使用wireshark通过图形界面的操作来实现捕获数据包并保存为文件. wireshark默认捕获的数据包保存为临时文件,如果最后退出时不选择 ...

  4. Oracle单机Rman笔记[1]---环境准备

    A.-----安装程序准备---- 1.拷贝oracle安装包到一个目录下 2.检查并修改hostname /etc/sysconfig/network中的hostname要与/etc/hosts中的 ...

  5. vue组件利用formdata图片预览以及上传

    转载修改 在项目中直接新建一个单文件页,复制一下代码即可       upload组件: <template> <div class="vue-uploader" ...

  6. ID绘图工具的使用5.29

    1.按住ALT拖动矩形工具,以中心绘制矩形.  绘制矩形的过程中,按住空格键可以调整矩形的位置. 2选择矩形工具,单击,可以精确输入尺寸. 3“窗口‘”信息“面板调出来.这样在绘制的时候可以边绘制边看 ...

  7. python全栈开发笔记---------数据类型****整理****

    一.数字 int(..) 二.字符串 replace/find/join/strip/startswith/split/upper/lower/format tempalet ='i am {name ...

  8. vuejs的双向绑定实现原理

    Vue在初始化的时候,会有两个大步骤: 1.Compile 从root的节点开始编译,根据正则表达式,把特殊的v-*类的标签,全部转换成对应的内存中的object 2.Observe 全部的data, ...

  9. 云硬盘性能测试工具FIO介绍

    一.云硬盘的性能衡量指标 云硬盘的性能指标一般通过以下几个指标进行衡量 IOPS:每秒的读写次数,单位为次(计数).存储设备的底层驱动类型决定了不同的IOPS 总IOPS:每秒执行的I/O操作总次数 ...

  10. setfacl语法

    1.setfacl的用途setfacl命令可以用来细分linux下的文件权限. chmod命令可以把文件权限分为u,g,o三个组,而setfacl可以对每一个文件或目录设置更精确的文件权限. 换句话说 ...