<玩转Django2.0>读书笔记:模板和模型
1. 模板内置标签
Django常用内置标签
| 标签 | 描述 |
|---|---|
| {% for %} | 遍历输出变量的内容 |
| {% if %} | 对变量进行条件判断 |
| {% csrf_token %} | 生成csrf_token标签,用于防护跨站请求伪造攻击 |
| {% url %} | 引用路由配置地址,生成相应的URL地址 |
| {% with %} | 将变量名重新命名 |
| {% load %} | 加载导入Django的标签库 |
| {% static %} | 读取静态资源文件 |
| {% extends xxx %} | 模板继承,xxx为模板文件名,使当前模板继承xxx模板 |
| {% block xxx %} | 重写父类模板的代码 |
{% url %}
相关的路由地址:
path('search/<int:page>',search_views,name='search')<a href="{% url 'search' 1%}">第一页</a>字符串search是URL的参数name的值,1是URL的变量page的值
for标签模板变量说明
| 变量 | 描述 |
|---|---|
| forloop.counter | 当前循环索引,从1开始计算 |
| forloop.counter0 | 当前循环索引,从0开始计算 |
| forloop.revcounter | 索引从最大数开始递减,直到索引到1的位置 |
| forloop.revcounter0 | 索引从最大数开始递减,直到索引到0的位置 |
| forloop.first | 当遍历的元素第一项为真 |
| forloop.last | 当遍历的元素最后一项为真 |
| forloop.parentloop | 在嵌套的for循环中,获取上层for循环的forloop |
2. 模板内置过滤器
参考:
3. 模型字段
参考:
4. 数据查询
单表查询
# all 全表查询
ps = Product.objects.all()
# 查询前5条
ps = Product.objects.all()[:5]
# values 查询某个字段
ps = Product.objects.values('ttype')
# distinct 去掉重复的
ps = ps.distinct()
# values_list 查询多个字段,列表元素以元组格式表示
ps = Product.objects.values_list('name','price')[:5]
# get 返回一条数据,没有查询到会报错
p = Product.objects.get(id=3)
print(p)
# filter 可返回空,返回列表
ps = Product.objects.filter(ttype="手机")
# SQl的or查询
from django.db.models import Q
ps = Product.objects.filter(Q(ttype="手机")|Q(ttype="出行"))
# count 统计数量
counter = Product.objects.all().count()
print(counter)
根据价格降序排列
默认升序,降序加"-"
ps = Product.objects.order_by("-price")
from django.db.models import Sum,Count,Avg
# annotate返回一个列表
# 分组后进行操作
# 数量统计
ps = Product.objects.values('ttype').annotate(Count('price'))
# 求和
ps = Product.objects.values('ttype').annotate(Sum('price'))
# 求平均数
ps = Product.objects.values('ttype').annotate(Avg('price'))
from django.db.models import Sum,Count,Avg
# aggregate返回一个字典
p = Product.objects.aggregate(type_count=Count('ttype'))
p = Product.objects.aggregate(Sum('id'))
p = Product.objects.aggregate(Avg('price'))
print(p,type(p))
匹配符
匹配符 说明 __exact 精确等于 __iexact 精确等于,忽略大小写 __contains 模糊匹配 __icontains 模糊匹配,忽略大小写 __gt 大于 __gte 大于等于 __lt 小于 __lte 小于等于 __in 判断是否在列表内 __startswith 以...开头 __istartswith 以...开头,忽略大小写 __endswith 以...结束 __iendswith 以...结束,忽略大小写 __range 在...范围内 __year 日期字段的年份 __month 日期字段的月份 __day 日期字段的天数 __isnull 判断是否为空 多表查询
t = ProductType.objects.get(id=1)
# 正向查询
print(t.typename)
# 反向查询
print(t.product_set.values('name'))
# 查询Product的字段name和模型ProductType的字段typename
ps = Product.objects.select_related('tttype').values('name','tttype__typename')
# 查询两个模型的全部数据
ps = Product.objects.select_related('tttype').all()
以模型Product作为查询对象主体,也可以使用模型ProductType,只要两表之间有外键关联即可
设置select_related的参数值为"tttype",该参数值是Product定义的tttype字段
如果在查询过程中需要使用另一个数据表的字段,可以使用
"外键__字段名"来指向该表的字段
<玩转Django2.0>读书笔记:模板和模型的更多相关文章
- <玩转Django2.0>读书笔记:表单
1. 表单字段 参考: 官方文档 Django表单字段汇总 2. 表单代码示例(forms.Form) # form.py代码 # 获取数据库数据 choices_list = [(i+1,v['ty ...
- <玩转Django2.0>读书笔记:URL规则和视图
1. 带变量的URL #urls.py from django.urls import path from .view import * urlpatterns = [ path('',index_v ...
- <玩转Django2.0>读书笔记:邮件和分页
1. 发送邮件 # settings.py设置 # 邮箱设置 EMAIL_USE_SSL = True # 邮件服务器 EMAIL_HOST = 'smtp.qq.com' # 邮件服务端口 EMAI ...
- 《玩转Django2.0》读书笔记-探究视图
<玩转Django2.0>读书笔记-探究视图 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 视图(View)是Django的MTV架构模式的V部分,主要负责处理用户请求 ...
- 《玩转Django2.0》读书笔记-编写URL规则
<玩转Django2.0>读书笔记-编写URL规则 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. URL(Uniform Resource Locator,统一资源定位 ...
- 《玩转Django2.0》读书笔记-Django配置信息
<玩转Django2.0>读书笔记-Django配置信息 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 项目配置是根据实际开发需求从而对整个Web框架编写相应配置信息. ...
- 《玩转Django2.0》读书笔记-Django建站基础
<玩转Django2.0>读书笔记-Django建站基础 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.网站的定义及组成 网站(Website)是指在因特网上根据一 ...
- 《深入了解java虚拟机》高效并发读书笔记——Java内存模型,线程,线程安全 与锁优化
<深入了解java虚拟机>高效并发读书笔记--Java内存模型,线程,线程安全 与锁优化 本文主要参考<深入了解java虚拟机>高效并发章节 关于锁升级,偏向锁,轻量级锁参考& ...
- 玩转 Django2.0 笔记1
模板静态 路由 urls.py urlpatterns = [ path("<year>/<int:month>/<slug:day>",my ...
随机推荐
- 利用crontab定时提交svn遇到的几个问题
交待下背景...公司开发组只有技术经理有服务器和数据库权限,还只是开发环境的..因为工作安排和权限限制,测试同学上线的时候,需要本人帮开发组的部分同事review代码并把代码提交到trunk.一开始手 ...
- 初始化仓库(git init)
创建新的仓库 首先进入需要初始化的目录,然后输入git init D:\Git\test λ git init Initialized empty Git repository in D:/Git/t ...
- 微信小程序出现 Expecting 'STRING','NUMBER','NULL','TRUE','FALSE','{','[', got INVALID
是因为,app.json中不能有注释,我将我上面注释的部分去掉,就可以了
- C# 学习之路--百度网盘爬虫设计与实现(一)
百度网盘爬虫 现在市面上出现了很多网盘搜索引擎,写这系列博文及爬虫程序的初衷: 更方面的查找资源 学习C# 学习爬虫的设计与实现 记录学习历程 自我监督 能力有限,如有不妥之处,还请各位看官点评.同在 ...
- java 中final关键字
1.final变量,一旦该变量被设定,就不可以再改变该变量的值. final关键字定义的变量必须声明时赋值.一旦一个对象引用被修饰为final后,它只能恒定指向一个对象,一个既是static和fina ...
- JAVA进阶20
1.可视化日历程序(简陋版) package cn.zh.abstrac; import java.text.DateFormat; import java.text.ParseException; ...
- 生成唯一UUID
目前有多种方式生成的UUID,根据算法,可确定是否唯一,使用IP和MAC自定义生成唯一主键较妥: // 获取MAC地址的方法 private static String getMACAddress(I ...
- 解决多个py模块调用同一个python的logging模块,打印日志冲突问题
前期对python中的logging模块进行了封装,这样自动化测试框架中的多个测试脚本(py)就可以使用同一个封装后的日志系统,这样各脚本中只需要引用一下即可,方面快捷.那么当我使用unittest框 ...
- go语言实现生产者-消费者
前言: 之前在学习操作系统的时候,就知道生产者-消费者,但是概念是模模糊糊的,好像是一直没搞明白. 其实很简单嘛,生产者生产,消费者进行消费,就是如此简单.了解了一下go语言的goroute,感觉实现 ...
- Python爬虫基础之正则表达式
一.Python正则表达式的基本使用 Python 3 使用re模块可以实现大部分的正则表达式情况. 1.re.compile(pattern, flags=0) re.compile构建匹配规则并返 ...