Python之路Day18
今天主要内容:Django Form、Django Admin、Django进阶
Django Admin
自带的验证:

Django Admin的定制
Django Admin 自定义actions:

注册modelAdmin的时候也可是使用下面的方法:
from django.contrib import admin
from app01 import models
# 定制book的Django admin管理
@admin.register(models.Book)
class BookAdmin(admin.ModelAdmin):
# 定义要在admin界面显示的字段,注意list_display默认是不能显示many_to_many字段的。
list_display = ["id", "title", "publisher", "publication_Date", "colored_status"]
...
前端颜色展示:
from django.db import models
from django.utils.html import format_html
class Book(models.Model):
title = models.CharField(max_length=100)
authors = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher)
publication_Date = models.DateField()
status_choice = (
("published", "已出版"),
("producing", "待出版"),
("forbidden", "禁书"),
)
status = models.CharField(choices=status_choice, max_length=32, default="producing")
def colored_status(self):
"""
在前端给状态字段根据不同状态添加不同的背景色
Django 1.7之后需要format_html将字符串渲染一下
用该函数名(colored_status)替换在model Admin中list_display中的status即可。
:return:
"""
global format_td
if self.status == "published":
format_td = format_html('<span style="padding:2px;background-color:yellowgreen;color:white">已出版</span>')
elif self.status == "producing":
format_td = format_html('<span style="padding:2px;background-color:pink;color:white">待出版</span>')
elif self.status == "forbidden":
format_td = format_html('<span style="padding:2px;background-color:orange;color:white">禁书</span>')
return format_td
colored_status.short_description = "状态"
def __str__(self):
return "《{}》".format(self.title)
class Meta:
verbose_name_plural = "书名"
单表内查询:
all_entries = Entry.objects.all() #查询所有
Entry.objects.filter(pub_date__year=2006) #查询所有pub_date为2006年的纪录
Entry.objects.all().filter(pub_date__year=2006) #与上面那句一样
>>> Entry.objects.filter( #链式查询
... headline__startswith='What'
... ).exclude(
... pub_date__gte=datetime.date.today()
... ).filter(
... pub_date__gte=datetime(2005, 1, 30)
... )
one_entry = Entry.objects.get(pk=1) #单条查询
Entry.objects.all()[:5] #查询前5条
Entry.objects.all()[5:10] #你猜
Entry.objects.order_by('headline')[0] #按headline排序取第一条
Entry.objects.filter(pub_date__lte='2006-01-01') #相当于sql语句SELECT * FROM blog_entry WHERE pub_date <= '2006-01-01';
Entry.objects.get(headline__exact="Cat bites dog") #相当于SELECT ... WHERE headline = 'Cat bites dog';
Blog.objects.get(name__iexact="beatles blog") #与上面相同,只是大小写不敏感
Entry.objects.get(headline__contains='Lennon') #相当 于SELECT ... WHERE headline LIKE '%Lennon%';
单表内查询语句
关联查询:(了不起的双下划线)
#This example retrieves all Entry objects with a Blog whose name is 'Beatles Blog': Entry.objects.filter(blog__name='Beatles Blog') Blog.objects.filter(entry__headline__contains='Lennon')
关联查询
Django models之F:对同一表内的不同字段进行查询
from django.db.models import F
Entry.objects.filter(n_comments__gt=F('n_pingbacks'))
从Entry表中找出所有评论数大于等于引用数的。
Entry.objects.filter(n_comments__gt=F('n_pingbacks') * 2)
从Entry表中找出所有评论数大于等于引用数2倍的。
Entry.objects.filter(rating__lt=F('n_comments') + F('n_pingbacks'))
从Entry表中找出所有rating小于等于评论数和引用数之和。
from datetime import timedelta
Entry.objects.filter(mod_date__gt=F('pub_date') + timedelta(days=3))
从Entry表中找出所有发布3天以后修改的。
Django models之Q
Python之路Day18的更多相关文章
- Python之路,Day18 - 开发一个WEB聊天来撩妹吧
Python之路,Day18 - 开发一个WEB聊天来撩妹吧 本节内容: 项目实战:开发一个WEB聊天室 功能需求: 用户可以与好友一对一聊天 可以搜索.添加某人为好友 用户可以搜索和添加群 每个 ...
- Python学习路程day18
Python之路,Day18 - Django适当进阶篇 本节内容 学员管理系统练习 Django ORM操作进阶 用户认证 Django练习小项目:学员管理系统设计开发 带着项目需求学习是最有趣和效 ...
- Python之路【第一篇】python基础
一.python开发 1.开发: 1)高级语言:python .Java .PHP. C# Go ruby c++ ===>字节码 2)低级语言:c .汇编 2.语言之间的对比: 1)py ...
- Python之路
Python学习之路 第一天 Python之路,Day1 - Python基础1介绍.基本语法.流程控制 第一天作业第二天 Python之路,Day2 - Pytho ...
- python之路 目录
目录 python python_基础总结1 python由来 字符编码 注释 pyc文件 python变量 导入模块 获取用户输入 流程控制if while python 基础2 编码转换 pych ...
- Python之路【第十九篇】:爬虫
Python之路[第十九篇]:爬虫 网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本.另外一些不常使用 ...
- Python之路【第十八篇】:Web框架们
Python之路[第十八篇]:Web框架们 Python的WEB框架 Bottle Bottle是一个快速.简洁.轻量级的基于WSIG的微型Web框架,此框架只由一个 .py 文件,除了Pytho ...
- Python之路【第十七篇】:Django【进阶篇 】
Python之路[第十七篇]:Django[进阶篇 ] Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...
- Python之路【第十六篇】:Django【基础篇】
Python之路[第十六篇]:Django[基础篇] Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...
随机推荐
- 老生常谈--Js继承小结
一直以来,对Js的继承有所认识,但是认识不全面,没什么深刻印象.于是,经常性的浪费很多时间重新看博文学习继承,今天工作不是特别忙,有幸看到了http://www.slideshare.net/stoy ...
- HDU 2167 Pebbles
题目大意:有个N*N( 3<=N<=15 )方阵, 可从中若干个数, 使其总和最大.取数要求, 当某一个数被选, 其周围8个数都不能选. 题解:记s数组为合法状态,即没有相邻的数字同时被选 ...
- 男装电子零售商East Dane即将面世_衣装_YOKA时尚网
男装电子零售商East Dane即将面世_衣装_YOKA时尚网 男装电子零售商East Dane即将面世
- iOS中Block介绍(二)内存管理与其他特性
我们在前一章介绍了block的用法,而正确使用block必须要求正确理解block的内存管理问题.这一章,我们只陈述结果而不追寻原因,我们将在下一章深入其原因. 一.block放在哪里 我们针对不同情 ...
- 【HDU】病毒侵袭持续中(AC自己主动机+map)
一開始一直WA,之后发现这道题不止一组输入,改成多组输入之后就过了. 利用map把每一个字符串映射到它相应的结点上即可了. 11909467 2014-10-19 11:54:00 Accepted ...
- BootStrap 智能表单系列 三 分块表单配置的介绍
相信广大博友肯定碰到过一个编辑页面分了很多块的情况,智能表单插件已经为您支持了这种情况, 代码如下(链接地址:https://github.com/xiexingen/Bootstrap-SmartF ...
- Web前端开发工程师为什么讨厌IE6!
- HTML静态网页(标签、表格)
HTML静态网页: 打开DREAMWEAVER,新建HTML,如下图: body的属性: bgcolor 页面背景色 background 背景壁纸.图片 text 文字颜色 topmargin ...
- java动手动脑课后思考题
public class SquareInt { public static void main(String[] args) { int result; ; x <= ; x++) { res ...
- 5.4 RegExp类型
ECMAScript通过RegExp类型来支持正则表达式.使用下面类似Perl的语法,就可以创建一个正则表达式. var expression=/pattern/flags; 复制代码 其中的模式(p ...