Django CreateView ModelForm下拉字段查询集过滤器

时间:2014-02-12 05:31:57

标签: django

这是我第一次真正使用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'

我认为我很接近,但显然我并不完全掌握。有任何想法吗?感谢。

2 个答案:

答案 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,则

会更有意义。