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. 模板内置过滤器

参考:

官方文档

Django过滤器

3. 模型字段

参考:

官方文档

django中models field详解

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>读书笔记:模板和模型的更多相关文章

  1. <玩转Django2.0>读书笔记:表单

    1. 表单字段 参考: 官方文档 Django表单字段汇总 2. 表单代码示例(forms.Form) # form.py代码 # 获取数据库数据 choices_list = [(i+1,v['ty ...

  2. <玩转Django2.0>读书笔记:URL规则和视图

    1. 带变量的URL #urls.py from django.urls import path from .view import * urlpatterns = [ path('',index_v ...

  3. <玩转Django2.0>读书笔记:邮件和分页

    1. 发送邮件 # settings.py设置 # 邮箱设置 EMAIL_USE_SSL = True # 邮件服务器 EMAIL_HOST = 'smtp.qq.com' # 邮件服务端口 EMAI ...

  4. 《玩转Django2.0》读书笔记-探究视图

    <玩转Django2.0>读书笔记-探究视图 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 视图(View)是Django的MTV架构模式的V部分,主要负责处理用户请求 ...

  5. 《玩转Django2.0》读书笔记-编写URL规则

    <玩转Django2.0>读书笔记-编写URL规则 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. URL(Uniform Resource Locator,统一资源定位 ...

  6. 《玩转Django2.0》读书笔记-Django配置信息

    <玩转Django2.0>读书笔记-Django配置信息 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 项目配置是根据实际开发需求从而对整个Web框架编写相应配置信息. ...

  7. 《玩转Django2.0》读书笔记-Django建站基础

    <玩转Django2.0>读书笔记-Django建站基础 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.网站的定义及组成 网站(Website)是指在因特网上根据一 ...

  8. 《深入了解java虚拟机》高效并发读书笔记——Java内存模型,线程,线程安全 与锁优化

    <深入了解java虚拟机>高效并发读书笔记--Java内存模型,线程,线程安全 与锁优化 本文主要参考<深入了解java虚拟机>高效并发章节 关于锁升级,偏向锁,轻量级锁参考& ...

  9. 玩转 Django2.0 笔记1

    模板静态  路由 urls.py urlpatterns = [ path("<year>/<int:month>/<slug:day>",my ...

随机推荐

  1. The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online J - Press the Button(思维)

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4056 题意 有一个按钮.一个灯.一个计时器和一个计数器,每按一次按钮,计时 ...

  2. java基于redis事务的秒杀实现

    package com.vian.user.service; import org.junit.Test; import org.springframework.util.CollectionUtil ...

  3. Fastjson反序列化漏洞研究

    0x01 Brief Description java处理JSON数据有三个比较流行的类库,gson(google维护).jackson.以及今天的主角fastjson,fastjson是阿里巴巴一个 ...

  4. Java中快捷键

    Fond表示字体 size表示字号 IDEA的基本配置 IDEA中常用的快捷键 Intellij IDEA基本快捷键 Ctrl+G 跳转到指定行 Ctrl+F4 关闭当前编辑页面 Ctrl+F 搜索 ...

  5. Lucene的中文分词器

    1 什么是中文分词器 学过英文的都知道,英文是以单词为单位的,单词与单词之间以空格或者逗号句号隔开. 而中文的语义比较特殊,很难像英文那样,一个汉字一个汉字来划分. 所以需要一个能自动识别中文语义的分 ...

  6. sqlyog连接mysql8.0

    1.本人安装的是mysql8.0社区版,安装包名称:mysql-installer-community-8.0.12.0.msi,可自行到官网下载. 2.安装完成后用sqlyog连接数据库出现密码乱码 ...

  7. vue老司机

    你和答案之间只差一个关键字 1.对象二级查找值渲染早于数据获取   解决vue.js 数据渲染成功仍报错的问题

  8. Urban Elevations UVA - 221

    题目大意:给出建筑的俯视图,以及每个建筑的左下角坐标,宽度,长度,高度.求正视图可观察到的建筑的编号 思路:建筑物的可见性等于南墙的可见性,依据左下角排序后,逐个判断每个建筑是否可见.对南墙的x坐标进 ...

  9. java控制多线程同时写一个文件

    最近出现一个需求,大体要做的就是控制多线程同时操作一个文件.当时第一个反应是不要用synchronized,太low了,然后我就使用了读写锁ReentrantReadWriteLock,然后写完静下来 ...

  10. Windows【端口被占用,杀死想啥的端口】

    windows 两步方法 netstat -ano | findstr "8080" taskkill /pid 4136-t -f linux 两步方法 ps -ef | gre ...