我的模型.py
relay = models.ForeignKey(RelayAddress,related_name="relay")
sister_relay = models.ForeignKey(RelayAddress,related_name="sister_relay")
"RelayAddress" is another table
我的管理员.py
sister = RelayAddress.objects.all()
dict=[]
for i in sister:
dict.append((i.id,i.display_name()))
#sister_relay_id=forms.ModelMultipleChoiceField(label=u'sister_relay',widget=forms.CheckboxSelectMultiple(),queryset=RelayAddress.objects.all())
sister_relay_id=forms.MultipleChoiceField(label=u'sister_relay',widget=forms.CheckboxSelectMultiple(),choices=dict)
def save(self, *args, **kwargs):
u = self.instance
my_list =self.cleaned_data['sister_relay_id']
...
...
return super(RelaySisterRelationForm, self).save(*args,**kwargs)
问题是:
当我保存时,发生错误,“无法分配[u'1']:RelayAddress.sister_relay 必须是 RelayAddress 实例”(像这样)
如果我不在模型中使用 ForeignKey,它可以工作。
但我想同时使用外键和复选框,从复选框中获取多个数据作为列表,并随意保存。
我也试过“ModelMultipleChoiceField”,不行。
我应该怎么做?非常感谢帮助!!!