字段名 | 参数 | 意义 |
---|---|---|
AutoField | 一个能够根据可用ID自增的 IntegerField | |
BooleanField | 一个真/假(true/false)字段 | |
CharField | (max_length) | 一个字符串字段,适用于中小长度的字符串。对于长段的文字,请使用TextField |
CommaSeparatedIntegerField | (max_length) | 一个用逗号分隔开的整数字段 |
DateField | ([auto_now], [auto_now_add]) | 日期字段 |
DateTimeField | 时间日期字段,接受跟 DateField 一样的额外选项 | |
EmailField | 一个能检查值是否是有效的电子邮件地址的 CharField | |
FileField | (upload_to) | 一个文件上传字段 |
FilePathField | (path,[match],[recursive]) | 一个拥有若干可选项的字段,选项被限定为文件系统中某个目录下的文件名 |
FloatField | (max_digits,decimal_places) | 一个浮点数,对应Python中的 float 实例 |
ImageField | (upload_to, [height_field] ,[width_field]) | 像 FileField 一样,只不过要验证上传的对象是一个有效的图片。 |
IntegerField | 一个整数。 | |
IPAddressField | 一个IP地址,以字符串格式表示(例如: “24.124.1.30” )。 | |
NullBooleanField | 就像一个 BooleanField ,但它支持 None /Null 。 | |
PhoneNumberField | 它是一个 CharField ,并且会检查值是否是一个合法的美式电话格式 | |
PositiveIntegerField | 和 IntegerField 类似,但必须是正值。 | |
PositiveSmallIntegerField | 与 PositiveIntegerField 类似,但只允许小于一定值的值,最大值取决于数据库. | |
SlugField | 嵌条 就是一段内容的简短标签,这段内容只能包含字母、数字、下划线或连字符。通常用于URL中 | |
SmallIntegerField | 和 IntegerField 类似,但是只允许在一个数据库相关的范围内的数值(通常是-32,768到+32,767) | |
TextField | 一个不限长度的文字字段 | |
TimeField | 时分秒的时间显示。它接受的可指定参数与 DateField 和 DateTimeField 相同。 | |
URLField | 用来存储URL的字段。 | |
USStateField | 美国州名称缩写,两个字母。 | |
XMLField | (schema_path) | 它就是一个 TextField ,只不过要检查值是匹配指定schema的合法XML。 |
通用字段参数列表(所有的字段类型都可以使用下面的参数,所有的都是可选的。)
参数名 | 意义 |
---|---|
null | 如果设置为 True 的话,Django将在数据库中存储空值为 NULL 。默认为 False 。 |
blank | 如果是 True ,该字段允许留空,默认为 False 。 |
choices | 一个包含双元素元组的可迭代的对象,用于给字段提供选项。 |
db_column | 当前字段在数据库中对应的列的名字。 |
db_index | 如果为 True ,Django会在创建表格(比如运行 manage.py syncdb )时对这一列创建数据库索引。 |
default | 字段的默认值 |
editable | 如果为 False ,这个字段在管理界面或表单里将不能编辑。默认为 True 。 |
help_text | 在管理界面表单对象里显示在字段下面的额外帮助文本。 |
primary_key | 如果为 True ,这个字段就会成为模型的主键。 |
radio_admin | 默认地,对于 ForeignKey 或者拥有 choices 设置的字段,Django管理界面会使用列表选择框()。如果 radio_admin 设置为 True 的话,Django就会使用单选按钮界面。 |
unique | 如果是 True ,这个字段的值在整个表中必须是唯一的。 |
unique_for_date | 把它的值设成一个 DataField 或者 DateTimeField 的字段的名称,可以确保字段在这个日期内不会出现重复值。 |
unique_for_month | 和 unique_for_date 类似,只是要求字段在指定字段的月份内唯一。 |
unique_for_year | 和 unique_for_date 及 unique_for_month 类似,只是时间范围变成了一年。 |
verbose_name | 除 ForeignKey 、 ManyToManyField 和 OneToOneField 之外的字段都接受一个详细名称作为第一个位置参数。 |
Field
required=True, 是否允许为空
widget=None, HTML插件
label=None, 用于生成Label标签或显示内容
initial=None, 初始值
help_text='', 帮助信息(在标签旁边显示)
error_messages=None, 错误信息 {'required': '不能为空', 'invalid': '格式错误'}
validators=[], 自定义验证规则
localize=False, 是否支持本地化
disabled=False, 是否可以编辑
label_suffix=None Label内容后缀
CharField(Field)
max_length=None, 最大长度
min_length=None, 最小长度
strip=True 是否移除用户输入空白
IntegerField(Field)
max_value=None, 最大值
min_value=None, 最小值
FloatField(IntegerField)
…
DecimalField(IntegerField)
max_value=None, 最大值
min_value=None, 最小值
max_digits=None, 总长度
decimal_places=None, 小数位长度
BaseTemporalField(Field)
input_formats=None 时间格式化
DateField(BaseTemporalField) 格式:2015-09-01
TimeField(BaseTemporalField) 格式:11:12
DateTimeField(BaseTemporalField)格式:2015-09-01 11:12
DurationField(Field) 时间间隔:%d %H:%M:%S.%f
…
RegexField(CharField)
regex, 自定制正则表达式
max_length=None, 最大长度
min_length=None, 最小长度
error_message=None, 忽略,错误信息使用 error_messages={‘invalid’: ‘…’}
EmailField(CharField)
…
FileField(Field)
allow_empty_file=False 是否允许空文件
ImageField(FileField)
…
注:需要PIL模块,pip3 install Pillow
以上两个字典使用时,需要注意两点:
- form表单中 enctype=“multipart/form-data”
- view函数中 obj = MyForm(request.POST, request.FILES)
URLField(Field)
…
BooleanField(Field)
…
NullBooleanField(BooleanField)
…
ChoiceField(Field)
…
choices=(), 选项,如:choices = ((0,‘上海’),(1,‘北京’),)
required=True, 是否必填
widget=None, 插件,默认select插件
label=None, Label内容
initial=None, 初始值
help_text=’’, 帮助提示
ModelChoiceField(ChoiceField)
… django.forms.models.ModelChoiceField
queryset, # 查询数据库中的数据
empty_label="---------", # 默认空显示内容
to_field_name=None, # HTML中value的值对应的字段
limit_choices_to=None # ModelForm中对queryset二次筛选
ModelMultipleChoiceField(ModelChoiceField)
… django.forms.models.ModelMultipleChoiceField
TypedChoiceField(ChoiceField)
coerce = lambda val: val 对选中的值进行一次转换
empty_value= ‘’ 空值的默认值
MultipleChoiceField(ChoiceField)
…
TypedMultipleChoiceField(MultipleChoiceField)
coerce = lambda val: val 对选中的每一个值进行一次转换
empty_value= ‘’ 空值的默认值
ComboField(Field)
fields=() 使用多个验证,如下:即验证最大长度20,又验证邮箱格式
fields.ComboField(fields=[fields.CharField(max_length=20), fields.EmailField(),])
MultiValueField(Field)
PS: 抽象类,子类中可以实现聚合多个字典去匹配一个值,要配合MultiWidget使用
SplitDateTimeField(MultiValueField)
input_date_formats=None, 格式列表:[’%Y–%m–%d’, ‘%m%d/%Y’, ‘%m/%d/%y’]
input_time_formats=None 格式列表:[’%H:%M:%S’, ‘%H:%M:%S.%f’, ‘%H:%M’]
FilePathField(ChoiceField) 文件选项,目录下文件显示在页面中
path, 文件夹路径
match=None, 正则匹配
recursive=False, 递归下面的文件夹
allow_files=True, 允许文件
allow_folders=False, 允许文件夹
required=True,
widget=None,
label=None,
initial=None,
help_text=’’
GenericIPAddressField
protocol=‘both’, both,ipv4,ipv6支持的IP格式
unpack_ipv4=False 解析ipv4地址,如果是::ffff:192.0.2.1时候,可解析为192.0.2.1, PS:protocol必须为both才能启用
SlugField(CharField) 数字,字母,下划线,减号(连字符)
…
UUIDField(CharField) uuid类型
Django Form内置字段