这是我第一次真正使用Django(1.6)并且我无法弄清楚这一点:
我正在尝试限制CreateView的下拉列表,以仅显示项目模型中具有活动状态(2)的项目:
class ProjectStatus(models.Model):
name = models.CharField(max_length=8)
class Project(models.Model):
name = models.CharField(max_length=30)
status = models.ForeignKey(ProjectStatus)
class WorkLog(models.Model):
project = models.ForeignKey(Project)
author = models.ForeignKey(User)
log_date = models.DateField( default=datetime.date.today)
accomplishments = models.TextField()
我的forms.py:
class WorklogCreateForm(ModelForm):
class Meta:
model = WorkLog
fields = [ 'project', 'log_date', 'accomplishments' ]
def __init__(self, *args, **kwargs):
super(WorklogCreateForm, self).__init__(self, *args, **kwargs)
self.fields['project'].queryset = Project.objects.filter(Project.status == 2)
和来自views.py的我的CreateView:
class WorklogCreate(CreateView):
form_class = WorklogCreateForm
success_url = reverse_lazy('dashboard')
但是我得到错误:
TypeError at /log/add/
'bool' object has no attribute '__getitem__'
如果我将过滤器更改为(Project.status.id == 2)
,请转到:
AttributeError at /log/add/
'ReverseSingleRelatedObjectDescriptor' object has no attribute 'id'
我认为我很接近,但显然我并不完全掌握。有任何想法吗?感谢。
答案 0 :(得分:5)
尝试按此过滤。
self.fields['project'].queryset = Project.objects.filter(status_id=2)
答案 1 :(得分:1)
你很接近,但由于某种原因混合了看起来像SQLAlchemy的语法。
此外,通过任意分配的数字(PK)过滤您的查询集的想法是荒谬的。
self.fields['project'].queryset = Project.objects.filter(status__name="foo")
如果仅将您的状态名称标记为unique=True
,则会更有意义。