1,前端样式
2,html代码
{% load asset_filter %} <div class="col-sm-2"> <select class="input-sm form-control select2 inline" name="ServiceModel"> <option value="">模块</option> {% for i in 'Ecs'|ecs_model_field_distinct:'ServiceModel' %} {% if i.0 %} <option value="{{ i.0 }}">{{ i.0 }}</option> {% endif %} {% endfor %} </select> </div>
3,后端代码
asset_filter.py 内容如下:
@register.filter(name='ecs_model_field_distinct') def ecs_model_field_distinct(model_name, field_name): ''' 获取model_name模块对象的某个属性field_name的distinct值,返回值的数组 :param model_name: :param field_name: :return: ''' asset_app = apps.get_app_config('rule') return asset_app.get_model(model_name).objects.all().values_list(field_name).distinct()
补充知识:django 模型类的常见字段约束,以及filter 过滤和查询
null
不设置时默认设置为False。设置为True时,数据库表字段中将存入NULL的记录。 null和blank组合使用,null=True,blank=True,表示该字段可以为空
blank
默认设置为False。设置为True时,表字段许可无任何输入。设置为False 时,表字段为必须输入的字段
choices
备选设置。选择列表选项,如果设置后,该字段的表单必然会是下拉选择的。这个值必须是一个有小括号构成的元组,每个元组前一个字段将存入数据库,后一个字段是显示给用户看的。
default
默认值,设置后在用户无输入时,表字段将以这个选项的内容来存储到数据库字段
可以为python 支持的任意数据对象
editable
如何设置为False,将不会参与到表单的验证。默认是设置为True的
error_messages
这个选项实现校验时的错误提示。是字典结构的内容。
help_text
在表单中形成输入提示内容
primary_key
主键,设置为 True ,该字段将启用为主键。 默认是 False
unique
设置为 True 启用不存在重复值输入的设定,默认为False
unique_for_date
设定日期不存在重复输入,默认为False
verbose_name
字段的文本标签
validators
校验选项,用来配置校验的方法,构成的列表。
max_length
最大输入字符串的长度
min_length
最少输入字符串的长度
AutoField
自动增值的id字段
primary_key=True
为必设置选项
BigAutoField
自动增值的id字段
支持 1 到 9223372036854775807,之间的序号
BigIntegerField
长整形字段
从 -9223372036854775808 到9223372036854775807 的整数
BinaryField
二进制字段
存储内存二进制数据,以 python bytes 对象来访问
BooleanField
布尔值字段
如果许可空的布尔值输入,换用 NullBooleadField
CharField
可变长字符串字段
max_length
有最大输入选项为必须设置的选项
DateField
日期字段
auto_now:
每一次保存对象时,Django 都会自动将该字段的值设置为当前时间。一般用来表示 "最后修改" 时间。要注意使用的是当前日期,而并非默认值,所以
不能通过重写默认值的办法来改变保存时间。
auto_now_add:
在第一次创建对象时,Django 自动将该字段的值设置为当前时间,一般用来表示对象创建时间。它使用的同样是当前日期,而非默认值
DateTimeField
有时刻的日期字段
auto_now=False
auto_now_add=False
当auto_now或者auto_now_add设置为True时,字段会有editable=True和blank=True的设定
; 固定精度的十进制数的字段。
它有两个必须的参数
max_digits:
数字允许的最大位数
decimal_places:
小数的最大位数
例如,要存储的数字最大值是999,而带有两个小数位,你可以使用
models.DecimalField(..., max_digits=5, decimal_places=2)
DurationField
日期时间增量型字段,存储着python timedelta 类数据
EmailField
邮件字段
FileField
文件字段
FilePathField
文件路径字段
FloatField
小数字段
ImageField
图片字段
IntegerField
整数字段
GenericIPAddressField ip
地址字段
NullBooleanField
许可null的布尔值字段
PositiveIntegerField
0 到 2147483647,支持所有数据库取值范围的安全整数。
PositiveSmallIntegerField
0 到 32767 支持所有数据库取值范围的安全短整数。
SlugField
SmallIntegerField
短整形字段
TextField
备注型字段,用于存储复杂
TimeField
时间字段
URLField
网址字段
UUIDField
Python UUID
数据对象,一个32位长度的ID字符串
映射字段
ForeignKeyField
一对多字段
映射字段
ManyToManyField
多对多字段
映射字段
OneToOneField
一对一字段
表的查询
查询
Person.objects.all().order_by(“-username”) 按照username字段值 反向排序
Person.objects.all()[:10]切片操作,获取10个人,不支持负索引,切片可以节约内存,不支持负切片
Person.objects.get(name=name) get获取不到报异常,不可取
get是用来获取一个对象的,如果需要获取满足条件的一些人,就要用到filter
Person.objects.filter(name="abc")# 等于
Person.objects.filter(name__exact="abc")名称严格等于 "abc" 的人
Person.objects.filter(name__iexact="abc")# 名称为abc 但是不区分大小写,可以找到ABC, Abc, aBC,这些都符合条件
***Person.objects.filter(name__contains="abc")# 名称中包含"abc"的人
***Person.objects.filter(name__icontains="abc")#名称中包含"abc",且abc不区分大小写
Person.objects.filter(name__regex="^abc")# 正则表达式查询
Person.objects.filter(name__iregex="^abc")#正则表达式不区分大小写
****
Person.objects.filter(age__gt=15)# age > 15
Person.objects.filter(age__lt=15)# age < 15
Person.objects.filter(age__gte=15)# age >= 15
Person.objects.filter(age__lte=15)# age <= 15
Person.objects.filter(age__ne=15)# age != 15
数据的归档
times = Person.objects.datas('add_time','month',order='desc') 默认正序,desc 倒序
month 表示精准到月
前端页面
{% for time in times %}
{{ time.year }} 年 {{time.month}} 月 {{time.day}}日 精准到月,这个time.day 永远是 1
{% endfor %}
filter 过滤有多个条件时
使用django的Q对象表示或者
from django.db.models import Q
Person.objects.filter(Q(name='张三') | Q(age=18))
查询过滤字段
__exact 精确等于 like 'aaa'
__iexact 精确等于 忽略大小写 ilike 'aaa'
__contains 包含 like'%aaa%'
__icontains 包含 忽略大小写 ilike '%aaa%',但是对于sqlite来说,contains的作用效果等同于icontains。
__gt 大于
__gte 大于等于
__lt 小于
__lte 小于等于
__in存在于一个list范围内
*****
__startswith以...开头
__istartswith以...开头忽略大小写
__endswith以...结尾
__iendswith以...结尾,忽略大小写
__range 在...范围内
__year日期字段的年份 如 .filter(add_time_year ='2018') 筛选添加时间年份为2018年的数据
__month日期字段的月份
__day日期字段的日
__isnull=True/False
以上这篇django filter过滤器实现显示某个类型指定字段不同值方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]