python---django中orm的使用(3)admin配置与使用
新建项目,并开启
python manage.py runserver
访问admin页面
http://127.0.0.1:8080/admin
补充:若是发现admin页面样式丢失:可能是因为在settings文件中的数据格式写错了,比如:
STATICFILES_DIRS 是元组类型,若是在os.path.join(BASE_DIR,'static')后面忘记加上逗号分隔符,则可能会丢失样式,无法找到
STATICFILES_DIRS = (
os.path.join(BASE_DIR,'static'),
)
此时并没有账号和密码:需要先配置数据库,在生成用户
配置数据库
python manage.py makemigrations
python manage.py migrate 创建用户
python manage.py createsuperuser
需要填写用户名,邮箱,密码
管理Django数据库的APP--->phpmyadmin,web版管理数据库
创建数据表:
# -*- coding: utf- -*-
from __future__ import unicode_literals from django.db import models # Create your models here. class Publisher(models.Model):
name = models.CharField(max_length=, verbose_name="名称")
address = models.CharField("地址", max_length=)
city = models.CharField('城市', max_length=)
state_province = models.CharField(max_length=)
country = models.CharField(max_length=)
website = models.URLField() class Meta:
verbose_name = '出版商'
verbose_name_plural = verbose_name def __str__(self):
return self.name class Author(models.Model):
name = models.CharField(max_length=) def __str__(self):
return self.name class AuthorDetail(models.Model):
sex = models.BooleanField(max_length=, choices=((, '男'), (, '女'),))
email = models.EmailField()
address = models.CharField(max_length=)
birthday = models.DateField()
author = models.OneToOneField(Author) class Book(models.Model):
title = models.CharField(max_length=)
authors = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher)
publication_date = models.DateField()
price = models.DecimalField(max_digits=, decimal_places=, default=) def __str__(self):
return self.title
models.py
python manage.py makemigrations
python manage.py migrate
配置数据库
在admin.py中配置数据库进行管理
from __future__ import unicode_literals from django.contrib import admin
from app01.models import * # Register your models here. admin.site.register(Book)
admin.site.register(Publisher) #会显示设置的verbose_name 在Admin中字段的显示名称
admin.site.register(Author)
python manage.py runserver
启动项目
再次访问
在web页面进行添加:
若是有中文则会出错,解决方法请看:python---补充django中文报错
若是想将页面设置为中文显示,可以设置settings文件:
#LANGUAGE_CODE = 'en-us'
LANGUAGE_CODE = 'zh-hans'
由于在建立orm对象时,__str__中只返回了title,所以页面显示只有书籍名称,其他信息并不全
class Book(models.Model):
title = models.CharField(max_length=)
authors = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher)
publication_date = models.DateField()
price = models.DecimalField(max_digits=, decimal_places=, default=) def __str__(self): #__str__需要返回字符串
return self.title
当没有__str__时,只会显示出
要想显示更多信息,需要我们在admin.py模块中自定义类,来设置显示的字段
class MyAdmin(admin.ModelAdmin):
list_display = ("title","price","publisher") #设置显示的字段,与原来__str__无关了 admin.site.register(Book,MyAdmin) #使MyAdmin与Book产生联系
admin.site.register(Publisher)
admin.site.register(Author)
可以修改models中的字段,设置别名在admin中显示
class Book(models.Model):
title = models.CharField(max_length=,verbose_name="书名")
搜索框:
class MyAdmin(admin.ModelAdmin):
list_display = ("title","price","publisher") #设置显示的字段,与原来__str__无关了
search_fields = ("title","price",) #会生成搜索框,元组中是允许搜索的字段
过滤器:
class MyAdmin(admin.ModelAdmin):
list_display = ("title","price","publisher") #设置显示的字段,与原来__str__无关了
search_fields = ("title","price",) #会生成搜索框,元组中是允许搜索的字段
list_filter = ("price","publisher") #生成过滤器,以price过滤
排序:
class MyAdmin(admin.ModelAdmin):
list_display = ("title","price","publisher") #设置显示的字段,与原来__str__无关了
search_fields = ("title","price",) #会生成搜索框,元组中是允许搜索的字段
list_filter = ("price","publisher") #过滤器
ordering = ("-price",) #排序,默认id排序,升序,降序,则使用在字段前使用 '-'
readonly_fields = [] #设置不允许修改
显示和隐藏:在添加和修改时使用:
fieldsets = [
(None, {'fields': ['title']}), #None代表其他字段隐藏,fields中字段显示
]
fieldsets = [
(None, {'fields': ['title']}),
('price information', {'fields': ['price', "publisher"], }), #组名为price information
]
fieldsets = [
(None, {'fields': ['title']}),
('price information', {'fields': ['price', "publisher"], 'classes': ['collapse']}), #classes样式折叠
]
python---django中orm的使用(3)admin配置与使用的更多相关文章
- Django中ORM介绍和字段及其参数
ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...
- Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM)
Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...
- 关于Django中ORM数据库迁移的配置
Django中ORM数据库迁移配置 1,若想将模型转为mysql数据库中的表,需要在settings中配置: DATABASES = { 'default': { 'ENGINE': 'django. ...
- 6月20日 Django中ORM介绍和字段、字段参数、相关操作
一.Django中ORM介绍和字段及字段参数 二.Django ORM 常用字段和参数 三.Django ORM执行原生SQL.在Python脚本中调用Django环境.Django终端打印SQL语句 ...
- Django 中ORM 的使用
一:Django 中 orm 的使用 1:手动新建一个数据库 2 :告诉Django连接哪个数据库 settings.py里配置数据库连接信息: #数据库相关的配置项 DATABASES ={ 'de ...
- Django中ORM的使用
Django中ORM的使用 ORM orm(object-relation-mapping)对象关系映射,即用对象来表示关系数据库中的表: 类 --> 表, 对象-->一行数据 对象的属性 ...
- Django中ORM对数据库的增删改查
Django中ORM对数据库数据的增删改查 模板语言 {% for line in press %} {% line.name %} {% endfor %} {% if 条件 %}{% else % ...
- Django中ORM实际应用
1. Django中ORM的使用 1. 手动新建一个数据库 2. 告诉Django连接哪个数据库 settings.py里面配置数据库连接信息: # 数据库相关的配置项 DATABASES = { ' ...
- Python Django中QQ邮箱授权码问题
Python Django中QQ邮箱授权码问题 系统及软件版本如下: Ubuntu Kylin 16.04 Python 3.5.1 Django 1.9.7 PyCharm Community Ed ...
- Django中ORM的聚合索引
Django中ORM的聚合索引 在Django中,聚合函数是通过aggregate方法实现的,aggregate方法返回的结果是一个字典 在使用时需要先导入模块from django.db.mod ...
随机推荐
- Paxos算法浅析
前言在文章2PC/3PC到底是啥中介绍了2PC这种一致性协议,从文中了解到2PC更多的被用在了状态一致性上(分布式事务),在数据一致性中很少被使用:而Paxos正是在数据一致性中被广泛使用,在过去十年 ...
- 利用 jrebel 热部署\远程调试\远程热部署 springboot项目 服务器上的代码
首先要在eclipse 中启用 启用以后在 resource 中生成了 rebel-remote.xml 然后build,把生成的jar包放到服务器上. 然后用下面的命令启动 java -agentp ...
- 策略模式与SPI机制,到底有什么不同?
这里说的策略模式是一种设计模式,经常用于有多种分支情况的程序设计中.例如我们去掉水果皮,一般来说对于不同的水果,会有不同的拨皮方式.此时用程序语言来表示是这样的: if(type == apple){ ...
- 前端示例MVC网站
前端示例MVC网站 ASP.NET Zero 包含了一个公共web站点的前端页面和一个登陆页面.当您第一次运行项目的时候可以看到,如下图所示: 该前端网站有两个页面,一个是主页和关于我们.这些页面的内 ...
- Unity 图文重现官方教程视频 2droguelike 第一集
初衷: 本人初学Unity,四处收集了一些视频和教材,学习和摸索了一段时间, 我发现官网教程简单易上手,只不过他是英文讲解不方便,我就想把他翻译翻译吧, 然后我又发现看视频学习要暂停回放好多遍,麻烦, ...
- PAT甲题题解-1034. Head of a Gang (30)-并查集
给出n和k接下来n行,每行给出a,b,c,表示a和b之间的关系度,表明他们属于同一个帮派一个帮派由>2个人组成,且总关系度必须大于k.帮派的头目为帮派里关系度最高的人.(注意,这里关系度是看帮派 ...
- PAT甲题题解-1119. Pre- and Post-order Traversals (30)-(根据前序、后序求中序)
(先说一句,题目还不错,很值得动手思考并且去实现.) 题意:根据前序遍历和后序遍历建树,输出中序遍历序列,序列可能不唯一,输出其中一个即可. 已知前序遍历和后序遍历序列,是无法确定一棵二叉树的,原因在 ...
- mysql新监语句需要前面加SET FOREIGN_KEY_CHECKS=0;
SET FOREIGN_KEY_CHECKS=0; -- ------------------------------ Table structure for guestbook-- -------- ...
- Android开发环境(发展演变)
初步接触android,要安装android开发工具时是使用eclipse,这是因为百度靠前的搜索项是eclipse来开 发android,而且那时还不知道android studio. 首先是下载配 ...
- centos 7 安装截图软件shutter
1.解决 epel-release依赖问题 ,执行命令: yum insatll epel-release 2.然后下载nux-dextop-release-0-5.el7.nux.noarch.rp ...