首页 > 编程语言 >Python基础day57 Django模板继承和模型层

Python基础day57 Django模板继承和模型层

时间:2023-08-02 19:55:47浏览次数:50  
标签:Python res Django filter models objects UserInfo print day57

模板之标签

就是在模板里面使用流程控制:if、else、elseif、for

标签看起来是这样的:{% tag %}

for标签

{% for person in person_list %}
    {{ forloop }}
    <p>{{ person.name }}</p>
{% endfor %}
{% for person in person_list %}  {#判断list是否有值,没有就走empty#}
    <p>{{ person }}</p>
{% empty %}
    <p>sorry,no person here</p>
'''
forloop.counter            The current iteration of the loop (1-indexed) 当前循环的索引值(从1开始)
forloop.counter0           The current iteration of the loop (0-indexed) 当前循环的索引值(从0开始)
forloop.revcounter         The number of iterations from the end of the loop (1-indexed) 当前循环的倒序索引值(从1开始)
forloop.revcounter0        The number of iterations from the end of the loop (0-indexed) 当前循环的倒序索引值(从0开始)
forloop.first              True if this is the first time through the loop 当前循环是不是第一次循环(布尔值)
forloop.last               True if this is the last time through the loop 当前循环是不是最后一次循环(布尔值)
forloop.parentloop         本层循环的外层循环
'''

# 遍历字典
{% for key, val in dic.items %}  {# 将字典的key和val值分开取出来 #}
    <p>{{ key }}:{{ val }}</p>
{% endfor %}
{% for d in dic %}  {# 取出字典的key值 #}
    <p>{{ d }}</p>
{% endfor %}
{% for k in dic.keys %}{# 取出字典的key值 #}
    <p>{{ k }}</p>
{% endfor %}
{% for v in dic.values %}{# 取出字典的value值 #}
    <p>{{ v }}</p>
{% endfor %}

if标签

{% if num > 100 or num < 0 %}
    <p>无效</p>
{% elif num > 80 and num < 100 %}
    <p>优秀</p>
{% else %}
    <p>凑活吧</p>
{% endif %}
{#if语句支持 and 、or、==、>、<、!=、<=、>=、in、not in、is、is not判断。#}

with起别名

d = {'username':'kevin','age':18,'info':'这个人有点意思','hobby':[111,222,333,{'info':'NB'}]}
{% with d.hobby.3.info as nb %}
    <p>{{ nb }}</p>
    {# 在with语法内就可以通过as后面的别名快速的使用到前面非常复杂获取数据的方式 #}
    <p>{{ d.hobby.3.info }}</p>
{% endwith %}

csrf_token

渲染标签

<form action="" method="post">
    {% csrf_token %}  {#加上这个就能够让post请求submit提交了,不用注释中间件了#}
    <input type="submit">
</form>

 

模板的继承

继承:继承之后的页面和被继承的页面一模一样

继承之后要自己划分要修改的区域

# 一个页面中应该有三块区域被修改
css
js
html

{% extends '要继承的页面' %}

{% block js %}  {#被继承页面中block包围的部分可以在继承页面中修改,可以划分多个block包围块#}
    <script>
        alert(123)
    </script>
{% endblock %}

    {% block css %}

    {% endblock %}
    
# 模板的导入
{% include 'hello.html' %}

模型层

测试环境的搭建

#tests.py的用法

# 制作django环境
import os
import sys


if __name__ == '__main__':
    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'day58_dj.settings')
    import django
    django.setup()

常见的十几种查询方法

filter().first() / filter().last()

# 在models文件中添加,能够返回username,在后续用以区分
    def __str__(self):
        return self.username

res = models.UserInfo.objects.filter().all()
        try:  # 防止出现列表为空的情况提前抛出错误
# 返回的是一个列表套字典
        print(res)  # <QuerySet [<UserInfo: jack>, <UserInfo: tom>, <UserInfo: jerry>, <UserInfo: tank>]>
        print(res[0])  # jack
# res[0] 是一个对象,可以使用点语法
        print(res[0].username)  # jack
        print(res[0].password)  # 123
    except Exception as z:
        print(z)

    res = models.UserInfo.objects.filter().first()  # 取出第一个值
    print(res)  # jack
# res = res[0] 是一个对象,可以使用点语法
    print(res.username)  # jack

    res = models.UserInfo.objects.filter().last()  # 取出最后一个值
    print(res)  # tank

values  value_list

    res = models.UserInfo.objects.values()
    # 列表套字典形式将每一组值当成一个字典输出,默认查询所有字段
    # <QuerySet [{'id': 1, 'username': 'jack', 'password': '123'}, {'id': 3, 'username': 'tom', 'password': '123'}, {'id': 4, 'username': 'jerry', 'password': '123'}, {'id': 5, 'username': 'tank', 'password': '123'}]>
    print(res)
    res1 = models.UserInfo.objects.values('username')
    # 可以限制查询的字段
    # <QuerySet [{'username': 'jack'}, {'username': 'tom'}, {'username': 'jerry'}, {'username': 'tank'}]>
    print(res1)
    # 支持循环,一个个字典分开拿出来
    for i in res:
        print(i)
    res2 = models.UserInfo.objects.values_list()
    # 列表套元组,元祖只取value值,其他用法和value一样,通过下标索引取对应的值
    # <QuerySet [(1, 'jack', '123'), (3, 'tom', '123'), (4, 'jerry', '123'), (5, 'tank', '123')]>
    print(res2)

查看原生SQL语句

res = models.UserInfo.objects.values_list()
    print(res)  # QuerySet对象,都有一个属性:query
    # SELECT "app01_userinfo"."id", "app01_userinfo"."username", "app01_userinfo"."password" FROM "app01_userinfo"
    print(res.query)
    # 限制:只有QuerySet对象才有query属性

'''第二种方式:在配置文件中设置, 但是必须要print才能显示出来'''
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
        },
    },
    'loggers': {
        'django.db.backends': {
            'handlers': ['console'],
            'propagate': True,
            'level': 'DEBUG',
        },
    }
}

排序

    res = models.UserInfo.objects.order_by('id')  # 默认是升序
    print(res)
    res1 = models.UserInfo.objects.order_by('-id')  # 降序
    print(res1)

反转

res=models.UserInfo.objects.all().order_by('-id').reverse()
print(res)
# 反转,先排序,数据要先有序才能反转

查看数量

    # 查看数量
    res = models.UserInfo.objects.count()
    print(res)

排除

    # 排除
    res = models.UserInfo.objects.exclude(id=1)
    print(res)

判断

    # exist:判断值是否存在
    res = models.UserInfo.objects.filter(pk=2).exists()
    print(res)

基于双下划线的查询

# 1 年龄大于35岁的数据
    res = models.UserInfo.objects.filter(age__gte=35).all()
    print(res)

    # 年龄小于10岁的数据 equal
    res = models.UserInfo.objects.filter(age__lte=10).all()
    print(res)

    # 年龄是10 或者 20 或者 30
    res = models.UserInfo.objects.filter(age__in=[10, 20, 30]).all()
    print(res)

    # 年龄在18到40岁之间的  首尾都要
    from table where age between 18 and 40
    res = models.UserInfo.objects.filter(age__range=[18, 40])
    print(res)

    # 查询出名字里面含有s的数据  模糊查询
    from table where username like '%s%'

    res = models.UserInfo.objects.filter(username__contains='s').all()
    print(res)
    # 用户名以s开头的
    res = models.UserInfo.objects.filter(username__startswith='s').all() # like 's%'
    res = models.UserInfo.objects.filter(username__endswith='s').all() # like '%s'
    print(res)

    # 查询出注册时间是 2023 5月
    res = models.UserInfo.objects.filter(reg_time__month=5, reg_time__year=2023, reg_time__day=1).all()
    res = models.UserInfo.objects.filter(reg_time__month=5, reg_time__day=1).all()
    print(res)

外键字段的查询

# 一对多的查询
# 图书和出版社是一对多的关系
# 增加一本图书?
# 外键字段的查询和增加
    # 增加一本图书
    models.Book.objects.create(title='洋哥自转', price=1000, publish_date='2023-08-01', publish_id=1)

    publish_obj = models.Publish.objects.filter(pk=20).first()
    try:
        publish_obj = models.Publish.objects.get(pk=20)
    except:
        pass
    models.Book.objects.create(title='洋哥自转2', price=2000, publish_date='2023-08-02', publish=publish_obj)
    print(publish_obj) # None

    # 删除一本图书
    models.Book.objects.filter(pk=1).delete()

    # 修改
    models.Book.objects.filter(pk=2).update(publish=publish_obj)
    models.Book.objects.filter(pk=2).update(publish_id=3)

 

标签:Python,res,Django,filter,models,objects,UserInfo,print,day57
From: https://www.cnblogs.com/zfq132/p/17601610.html

相关文章

  • 【python_3】PyCharm开发工具的安装和基础使用!
    前言Python程序的开发有许多种方式,一般常见的:python解释器环境内,执行单行代码;使用python解释器程序,执行python代码文件;使用第三方IDE(集成开发工具),如PyCharm软件,开发python程序;1.下载pycharm官网:https://www.jetbrains.com/2.安装点击next:点击next:点击next:点击next:点击Install......
  • 基础阶段python小总结暨下个阶段预习
    基础阶段基本与函数基本已经截至了,这些很简单,资料很多,当然我个人的更新的不是很全,只能做一个参考。下个阶段class预习简单做一个学生通信管理系统。任务说明:"学生信息管理系统v1.0""【1】、添加学生信息""【2】、删除学生信息""【3】、修改学生信息""【4......
  • Django之models模型层、测试环境的搭建
    一、models层中常见的几种查询方法1、2、  二、测试环境的搭建1、app应用中默认有一个tests.py的测试文件,拷贝manage.py的内容如下到tests.py中此时这个测试文件就能使用django环境了importosimportsysif__name__=='__main__':os.environ.setdefault('DJA......
  • python中发送测试报告邮件
    要在Python中发送测试报告邮件,可以使用smtplib和email库来实现。以下是简单的代码,以qq邮箱为例,注:邮箱密码得事先申请,如下:先开启服务,之后再申请(需绑定一手机号)代码如下:importsmtplibfromemail.mime.textimportMIMETextfromemail.mime.multipartimportMIMEMultipartfromem......
  • python3 番外篇之Linux环境安装问题
    问题一、Linux主机openSSL版本较老[root@zabbix-serveralertscripts]#python3feishu.pyTraceback(mostrecentcalllast):File"feishu.py",line3,in<module>importrequestsFile"/usr/local/python3.8/lib/python3.8/site-packages/reque......
  • Python-入门
    介绍Python (python.org)LearnXinYminutes (learnxinyminutes.com)Regexinpython (jaywcjlove.github.io)helloword>>>print("Hello,World!")Hello,World!Python中著名的“HelloWorld”程序变量age=18#年龄是int类型name="John"#nam......
  • Python 字符串
    类数组>>>hello="Hello,World">>>print(hello[1])e>>>print(hello[-1])d获取位置 1 或最后的字符循环>>>forcharin"foo":...print(char)foo遍历单词 foo 中的字母切片字符串┌───┬───┬───┬───┬───┬───┬───┐|m|y|b|......
  • 【python_1】第一个python程序!
    打开CMD(命令提示符)程序,输入python并回车;输入:print("HelloWorld!")然后回车;print代表的是打印输出的意思;这段代码的含义就是:在屏幕上输出引号内的内容。代码中使用的符号()""必须是英文符号。持续更新【python】系列!有需要的请移步秃头程序媛!......
  • python开发实战——ip池
    前言代理IP池是一组可用的代理IP地址,用于访问网站或执行其他网络请求。它可以帮助我们在网络请求时隐藏我们的真实IP地址,从而提高网络安全性、匿名性和稳定性。同时,代理IP池还可以通过定时更新和测试代理IP,保证代理IP的有效性和稳定性。本文将介绍如何使用Python编写代理IP池,包括......
  • # yyds干货盘点 # 盘点一个Python递归的基础题目
    大家好,我是皮皮。一、前言前几天在Python黄金群【维哥】问了一个Python递归的基础问题,一起来看看吧。看上去代码没多少哈,但是韵味无穷。二、实现过程很多初学者遇到这个问题,很容易把答案说成是3,2,2这样,其实正好相反,这里【巭孬嫑勥烎】给了一个解释。这么一看好像还是不太好理解,看看......