模型字段
序列本身由正好两个项目的迭代项组成(例如,[(A,B),(A,C)…]),作为该字段的选择。如果给出了选择,它们将通过模型验证来执行。默认表单部分将是包含这些选项的选择框,而不是标准文本字段。 每个元组中的第一个元素是要在模型上设置的实际值,第二个元素是人类可读的名称。例如:
代码语言:javascript复制YEAR_IN_SCHOOL_CHOICES = [
('FR', 'Freshman'),
('SO', 'Sophomore'),
('JR', 'Junior'),
('SR', 'Senior'),
('GR', 'Graduate'),
]
尽管可以在模型类外部定义选择列表,然后引用它,但在模型类中定义选择和每个选择的名称可以在使用它的类中保留所有这些信息,并帮助引用这些选择(例如,Student.SOPHOMORE将在导入学生模型的任何位置工作)。 还可以将可用的选项收集到可用于组织目的的命名组中:
代码语言:javascript复制from django.db import models
class Student(models.Model):
FRESHMAN = 'FR'
SOPHOMORE = 'SO'
JUNIOR = 'JR'
SENIOR = 'SR'
GRADUATE = 'GR'
YEAR_IN_SCHOOL_CHOICES = [
(FRESHMAN, 'Freshman'),
(SOPHOMORE, 'Sophomore'),
(JUNIOR, 'Junior'),
(SENIOR, 'Senior'),
(GRADUATE, 'Graduate'),
]
year_in_school = models.CharField(
max_length=2,
choices=YEAR_IN_SCHOOL_CHOICES,
default=FRESHMAN,
)
def is_upperclass(self):
return self.year_in_school in {self.JUNIOR, self.SENIOR}
每个元组中的第一个元素是应用于组的名称。第二个元素是二进制元组的迭代。每个二进制元组包含一个值和一个可读的选项名称。分组选项可以与单个列表中的未分组选项组合(例如本例中的“未知”选项)。
代码语言:javascript复制from django.utils.translation import gettext_lazy as _
class Student(models.Model):
class YearInSchool(models.TextChoices):
FRESHMAN = 'FR', _('Freshman')
SOPHOMORE = 'SO', _('Sophomore')
JUNIOR = 'JR', _('Junior')
SENIOR = 'SR', _('Senior')
GRADUATE = 'GR', _('Graduate')
year_in_school = models.CharField(
max_length=2,
choices=YearInSchool.choices,
default=YearInSchool.FRESHMAN,
)
def is_upperclass(self):
return self.year_in_school in {
self.YearInSchool.JUNIOR,
self.YearInSchool.SENIOR,
}
对于每个带有选项集的模型字段,Django将添加一个方法来检索字段当前值的可读名称。 注意,选择可以是任何序列对象——不一定是列表或元组。这允许动态构建选择。然而,如果发现自己将芯片魔法更改为动态,则最好使用带有ForeignKey的适当数据库表。芯片用于静态数据。如果有的话,他们不应该改变太多。
primary_key
如果设置为True,则将此字段设置为模型的主键。 如果没有为模型中的任何字段指定主键_Key=True,Django将自动添加一个字段来保存主键,因此不需要在任何字段上设置主键_Key=True,除非想覆盖默认主键行为。自动创建的主键字段的类型可以在每个应用程序的AppConfig default_auto_field中找到,或者在field配置中全局指定default_auto_field
代码语言:javascript复制def user_directory_path(instance, filename):
# file will be uploaded to MEDIA_ROOT/user_<id>/<filename>
return 'user_{0}/{1}'.format(instance.user.id, filename)
class MyModel(models.Model):
upload = models.FileField(upload_to=user_directory_path)
primary_Key=True表示null=False,unique=True。一个对象只允许有一个主键。 主键字段是只读的。如果更改现有对象的主键值并保存它,则会在旧对象旁边创建一个新对象。
代码语言:javascript复制from django.core.files.base import ContentFile
myfile = ContentFile("hello world")
在的配置文件中,需要添加MEDIA_ROOT。ROOT被定义为希望Django存储上传文件的目录的完整路径。(为了提高性能,这些文件不存储在数据库中。)MEDIA_ URL定义为目录的基本公共URL。确保网络服务器的用户帐户可以写入此目录。
代码语言:javascript复制from django.core.files import File
# Open an existing file using Python's built-in open()
f = open('/path/to/hello.world')
myfile = File(f)
将FileField或ImageField添加到模型中,并定义upload_to选项,指定MEDIA_ ROOT的子目录用于上载文件。 所有这些都将存储在数据库中的文件路径中(相对于MEDIA_ROOT)。可能会使用Django提供的方便的url属性。例如,如果ImageField名为mug_Shot,则可以在模板中使用{{object.mug_Shot.url}}获取图像的绝对路径。 在Python Time实例中使用datetime。接受与DateField相同的自动填充选项。 此字段的默认表单部分是TimeInput。一些JavaScript快捷方式已添加到管理中。