簡體   English   中英

Django CreateView ModelForm下拉字段查詢集過濾器

[英]Django CreateView ModelForm dropdown field queryset filter

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

我覺得我很接近,但顯然並不完全掌握。 有任何想法嗎? 謝謝。

嘗試像這樣過濾。

 self.fields['project'].queryset = Project.objects.filter(status_id=2)

你很接近,但由於某些原因混合了看起來像SQLAlchemy的語法。

此外,通過任意分配的數字(PK)過濾您的查詢集的想法是荒謬的。

self.fields['project'].queryset = Project.objects.filter(status__name="foo")

如果只有你的狀態名稱被標記為unique=True ,那么會更有意義。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM