我对Django仍然很缺乏经验,但我在这个问题上陷入困境。我得到了一个几乎完成的项目,父母可以在他们的孩子上填写评估,然后研究人员可以使用Django和Postgresql收集和存储这些数据。有两个不同的应用程序有几个相关的模型,它们都与另一个相关。 “仪器”(测试类型)可以有多个研究,而这些研究又可以有多个参与者。我做了一个很糟糕的图像来描述我的意思。基于远程相关模型的Django表单验证
有一种形式,BackgroundForm,收集人口统计信息(年龄,出生体重等)。然后将此数据存储在模型中,使用参与者的管理标识BackgroundInfo。我遇到的问题使表单验证更加灵活。某些仪器(测试)是针对特定年龄的,我不确定如何将这些信息一直提供给BackgroundForm验证,因为这些信息位于几个关系之外。有没有一种方法来启用表单验证,根据位于几个关系之外的模型的属性进行验证?
cdi_forms/forms.py
class BackgroundForm(BetterModelForm):
age = forms.IntegerField()
sex = forms.ChoiceField(choices=(('M', 'Male'), ('F', 'Female'), ('O', 'Other')), widget=forms.RadioSelect)
def clean(self):
cleaned_data = super(BackgroundForm, self).clean()
if cleaned_data.get('age') == '':
self.add_error('age', 'Please enter your child\'s DOB in the field above.')
class Meta:
model = BackgroundInfo
exclude = ['administration']
cdi_forms/models.py
class BackgroundInfo(models.Model):
administration = models.OneToOneField("researcher_UI.administration")
age = models.IntegerField(verbose_name = "Age (in months)")
sex = models.CharField(max_length = 1, choices = (('M', "Male"), ('F', "Female"), ('O', "Other")))
researcher_UI/models.py
class administration(models.Model):
study = models.ForeignKey("study")
subject_id = models.IntegerField()
class study(models.Model):
researcher = models.ForeignKey("auth.user")
name = models.CharField(max_length = 51)
instrument = models.ForeignKey("instrument")
class instrument(models.Model):
name = models.CharField(max_length = 51, primary_key=True)
language = models.CharField(max_length = 51, blank = True)
min_age = models.IntegerField(verbose_name = "Minimum age", null = True)
max_age = models.IntegerField(verbose_name = "Maximum age", null = True)