目录
一.过滤器
1.什么是过滤器
2.语法
3.统计字符串长度
4.默认值
5.文件大小
6.日期格式化
原始格式
格式化输出
7.切片操作
8.切取摘要
字符
9.移除指定字符
10.拼接字符
11.加法
12.取消转义
前端转义
后端转义
二.标签
1.forloop
2.if 语句
3.混用forloop+if
三.模型层
1.数据准备
(1)测试脚本
(2)数据
2.单表的操作
(1)数据的增加
(2)数据的删除
(3)数据的更改
3.查看SQL语句的方式
(1)方式一
(2)方式二
4.双下划线查询
过滤器就类似于模板语法内置的内置方法
Django内置有60多个过滤器
{{ 数据|过滤器:参数 }}
{{ c|length }}
def length(value):
"""Returns the length of the value - useful for lists."""
try:
return len(value)
except (ValueError, TypeError):
return 0
默认值{{ f|default:"这是默认值" }}
def default_if_none(value, arg):
"""If value is None, use given default."""
if value is None:
return arg
return value
文件大小 {{ file|filesizeformat }}
def filesizeformat(bytes_):
"""
Formats the value like a 'human-readable' file size (i.e. 13 KB, 4.1 MB,
102 bytes, etc.).
"""
try:
bytes_ = float(bytes_)
except (TypeError, ValueError, UnicodeDecodeError):
value = ungettext("%(size)d byte", "%(size)d bytes", 0) % {'size': 0}
return avoid_wrapping(value)
def filesize_number_format(value):
return formats.number_format(round(value, 1), 1)
KB = 1 << 10
MB = 1 << 20
GB = 1 << 30
TB = 1 << 40
PB = 1 << 50
negative = bytes_ < 0
if negative:
bytes_ = -bytes_ # Allow formatting of negative numbers.
if bytes_ < KB:
value = ungettext("%(size)d byte", "%(size)d bytes", bytes_) % {'size': bytes_}
elif bytes_ < MB:
value = ugettext("%s KB") % filesize_number_format(bytes_ / KB)
elif bytes_ < GB:
value = ugettext("%s MB") % filesize_number_format(bytes_ / MB)
elif bytes_ < TB:
value = ugettext("%s GB") % filesize_number_format(bytes_ / GB)
elif bytes_ < PB:
value = ugettext("%s TB") % filesize_number_format(bytes_ / TB)
else:
value = ugettext("%s PB") % filesize_number_format(bytes_ / PB)
if negative:
value = "-%s" % value
return avoid_wrapping(value)
current_time = datetime.datetime.now()
日期格式化 {{ current_time }}
日期格式化 July 12, 2023, 3:57 p.m.
日期格式化 {{ current_time|date:'Y-m-d H:m:s' }}
日期格式化 2023-07-12 15:07:45
支持步长切片
c = "这是一个示例"
切片操作 {{ c|slice:'0:4:2' }}
切片操作 这一
不会将 . 算进切取个数
# 切取单词
sentence = 'I just need someone who will never abandon me'
切取单词 {{ sentence|truncatewords:9 }}
切取单词 I just need someone who will never abandon me
sentence = 'I just need someone who will never abandon me'
移除指定字符,例空格 {{ sentence|cut:" " }}
移除指定字符,例空格 Ijustneedsomeonewhowillneverabandonme
d = ["你好", "我好", "大家好"]
拼接字符 {{ d|join:"$" }}
拼接字符 你好$我好$大家好
a = 123
拼接字符(加法) {{ a|add:10 }}
拼接字符(加法) 133
def add(value, arg):
"""Adds the arg to the value."""
try:
return int(value) + int(arg)
except (ValueError, TypeError):
try:
return value + arg
except Exception:
return ''
以后在写全栈项目时,前端代码不一定必须在前端页面书写,也可以选择先在后端写好再传递给前端页面展示
msg = '斋藤
'
转义字符(不转义) {{ msg }}
转义字符(转义) {{ msg|safe }}
转义字符(不转义) 斋藤
转义字符(转义)
斋藤(已变成h1标题格式)
from django.utils.safestring import mark_safe
res = mark_safe('飞鸟
')
转义字符(转义) {{ res }}
转义字符(转义)
飞鸟(已变成h1标题格式)
d = ["你好", "我好", "大家好"]
{% for re in d %}
{{ forloop }}
{% endfor %}
标签
{'parentloop': {}, 'counter0': 0, 'counter': 1, 'revcounter': 3, 'revcounter0': 2, 'first': True, 'last': False}
{'parentloop': {}, 'counter0': 1, 'counter': 2, 'revcounter': 2, 'revcounter0': 1, 'first': False, 'last': False}
{'parentloop': {}, 'counter0': 2, 'counter': 3, 'revcounter': 1, 'revcounter0': 0, 'first': False, 'last': True}
d = ["你好", "我好", "大家好"]
{% for re in d %}
{{ re }}
{% endfor %}
你好
我好
大家好
f = True
{% if f %}
你好
{% else %}
我好
{% endif %}
你好
d = ["你好", "我好", "大家好"]
{% for re in d %}
{% if forloop.first %}
第一次循环
{% elif forloop.last %}
最后一次循环
{% else %}
{{ re }}
{% endif %}
{% empty %}
for循环的对象是空,不支持for循环
{% endfor %}
第一次循环
我好
最后一次循环
测试脚本
测试环境的准备
这内容其实就是最外部 manage.py 文件中的上面几句话
from django.test import TestCase
# Create your tests here.
import os
if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "day07.settings")
import django
django.setup()
# 在下面书写我们需要测试的代码
# 即所有的测试代码都必须等待环境准备完毕之后才能书写
在models里面创建我们需要的数据库中的表
from django.db import models
# Create your models here.
class User(models.Model):
name = models.CharField(verbose_name="姓名", help_text="姓名", max_length=32)
age = models.IntegerField(verbose_name="年龄", help_text="年龄")
register_time = models.DateTimeField(verbose_name="注册时间", help_text="注册时间")
'''
DateField
DateTimeField
两个关键参数
auto_now : 每次操作数据的时候该字段会自动将当前时间更新
auto_now_add : 在创建数据的时候会自动将当前创建时间记录下来,只要不是人为修改,就不会发生更改
'''
配置数据库文件(settings.py)
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
# 数据库名字
'NAME': 'django_day10',
# 用户
"USER": "root",
# 密码
"PASSWORD": "1314521",
# IP
"HOST": "127.0.0.1",
# 端口
"PORT": 3306,
# 编码集
"CHARSET": "utf8",
}
}
在项目下的init.py中声明数据库类型
import pymysql
pymysql.install_as_MySQLdb()
create
update
delete
all
first
filter
from django.test import TestCase
# Create your tests here.
import os
if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "day07.settings")
import django
django.setup()
# 在下面书写我们需要测试的代码
# 即所有的测试代码都必须等待环境准备完毕之后才能书写
from app01 import models
# (1)增加数据
# register_time (1)支持自己指定传值
res = models.User.objects.create(name="dream", age=18, register_time='2023-06-09')
# 返回值为对象本身
print(res) # User object
# register_time (2)支持传入日期对象
import datetime
# 生成一个当前的时间对象
c_time = datetime.datetime.now()
user_obj = models.User.objects.create(name="chimeng", age=18, register_time=c_time)
# 保存数据
user_obj.save()
# 【2】删除数据
# pk : 自动查找到当前表的主键字段,指代的就是当前表的主键字段
# 使用 pk 后不需要知道当前表的主键字段 , 他会自动帮我们查找并匹配
# (1)方式一
res = models.User.objects.filter(pk=4).delete()
print(res) # (1, {'app01.User': 1})
# (2)方式二
# 拿到当前用户对象
user_obj = models.User.objects.filter(pk=1).first()
# 利用对象的方法进行删除
user_obj.delete()
# 【3】数据的更改
# (1)方式一
res = models.User.objects.filter(pk=5).update(name="mengmeng")
print(res) # 1
# (2)方式二
# 返回的就是当前的数据对象
# 不推荐使用 : 如果查询的数据不存在会直接报错 ,fileter不会
user_onj = models.User.objects.get(pk=5)
# 调用对象更改数据
user_onj.name = "xiaomeng"
user_onj.save()
只有queryset对象才能使用该方法
res_list = models.User.objects.values_list('name', 'age')
# 返回的数据格式为列表套元祖 - 本质上是一个 QuerySet 对象 ,而不是真的列表
print(res_list) #
# 该语句可以查看当前执行命令的 SQL 语句 - 只有queryset对象才能使用该方法
print(res_list.query) # SELECT `app01_user`.`name`, `app01_user`.`age` FROM `app01_user`
其他方法:
from django.test import TestCase
# Create your tests here.
import os
if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "day07.settings")
import django
django.setup()
# 在下面书写我们需要测试的代码
# 即所有的测试代码都必须等待环境准备完毕之后才能书写
from app01 import models
# # 【1】增加数据
# # register_time (1)支持自己指定传值
# res = models.User.objects.create(name="dream", age=18, register_time='2023-06-09')
# # 返回值为对象本身
# print(res) # User object
# # register_time (2)支持传入日期对象
#
# import datetime
#
# # 生成一个当前的时间对象
# c_time = datetime.datetime.now()
# user_obj = models.User.objects.create(name="chimeng", age=18, register_time=c_time)
# # 保存数据
# user_obj.save()
# # 【2】删除数据
# # pk : 自动查找到当前表的主键字段,指代的就是当前表的主键字段
# # 使用 pk 后不需要知道当前表的主键字段 , 他会自动帮我们查找并匹配
# # (1)方式一
# res = models.User.objects.filter(pk=4).delete()
# print(res) # (1, {'app01.User': 1})
# # (2)方式二
# # 拿到当前用户对象
# user_obj = models.User.objects.filter(pk=1).first()
# # 利用对象的方法进行删除
# user_obj.delete()
#
# # 【3】数据的更改
# # (1)方式一
# res = models.User.objects.filter(pk=5).update(name="mengmeng")
# print(res) # 1
# # (2)方式二
# # 返回的就是当前的数据对象
# # 不推荐使用 : 如果查询的数据不存在会直接报错 ,fileter不会
# user_onj = models.User.objects.get(pk=5)
# # 调用对象更改数据
# user_onj.name = "xiaomeng"
# user_onj.save()
###############必知必会十三条#################
# (1) all() - 查询所有数据
# (2) filter() - 带有过滤条件的查询
# (3) get() - 根据条件拿数据对象,但是条件不存在会直接抛出异常
# (4) first() - 拿queryset中的第一个元素
# (5) last() - 拿queryset中的最后一个元素
# (6) values() - 可以指定获取的数据字段
res = models.User.objects.values('name')
# 返回的数据格式为列表套字典 - 本质上是一个 QuerySet 对象 ,而不是真的列表
print(res) #
# (7) values_list() - 可以指定获取的数据字段
res_list = models.User.objects.values_list('name', 'age')
# 返回的数据格式为列表套元祖 - 本质上是一个 QuerySet 对象 ,而不是真的列表
print(res_list) #
# 该语句可以查看当前执行命令的 SQL 语句 - 只有queryset对象才能使用该方法
print(res_list.query) # SELECT `app01_user`.`name`, `app01_user`.`age` FROM `app01_user`
# (8) distinct() - 去重(带有主键就意味着数据存在不一样的地方,所以一定要去除主键后再去重)
# distinct 方法在主键存在时,无法对含有不同主键的相同数据进行去重
# 但是我们可以通过拿到指定字段的数据后,对筛选出的数据进行去重
res = models.User.objects.values('name', 'age').distinct()
print(res)
# (9) order_by() - 排序
# 默认升序
res = models.User.objects.order_by('age')
print(res)
# 降序
res = models.User.objects.order_by('-age')
print(res)
# (10) reverse() - 反转的前提是数据已经经过排序过的数据
# 只能对有序的数据进行反转
res = models.User.objects.order_by('age').reverse()
print(res)
# (11) count() - 统计当前数据的个数
res = models.User.objects.count()
print(res)
# (12) exclude() - 排出在外
# 将某个数据排出在结果之外
res = models.User.objects.exclude(user="dream")
# (13) exists() - 是否存在 - 返回布尔值 - 用处不大,因为数据本身就有布尔值的状态
res = models.User.objects.filter(pk=5).exists()
print(res)
所有SQL语句都可以使用
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console':{
'level':'DEBUG',
'class':'logging.StreamHandler',
},
},
'loggers': {
'django.db.backends': {
'handlers': ['console'],
'propagate': True,
'level':'DEBUG',
},
}
}
# 神奇的双下划线查询
# (1)年龄大于35岁的数据
res = models.User.objects.filter(age__gt=35)
print(res)
# (2)年龄小于35岁的数据
res = models.User.objects.filter(age__lt=35)
print(res)
# (3)年龄大于等于35岁的数据
res = models.User.objects.filter(age__gte=35)
print(res)
# (4)年龄小于等于35岁的数据
res = models.User.objects.filter(age__lte=35)
print(res)
# (5)年龄是18或者32或者40
res = models.User.objects.filter(age__in=(18, 32, 40))
print(res)
# (6)年龄是18-40之间 - 首尾都要
res = models.User.objects.filter(age__range=(18, 40))
print(res)
# (7)查询出名字中含有 n 的数据 -- 模糊查询
res = models.User.objects.filter(name__contains='n')
print(res)
# (7.1)是否区分大小写?
res = models.User.objects.filter(name__contains='N')
print(res)
# 默认区分大小写
# (7.2)忽略大小写
res = models.User.objects.filter(name__icontains='N')
print(res)
# (8)以什么开头/结尾
res = models.User.objects.filter(name__startswith='d')
print(res)
res = models.User.objects.filter(name__endswith='m')
print(res)
# (9)查询出注册时间是2020年1月份的数据/年/月/日
res = models.User.objects.filter(register_time__month='1')
print(res)
res = models.User.objects.filter(register_time__year='2020')
print(res)
res = models.User.objects.filter(register_time__day='28')
print(res)