我今天刚开始玩Django,到目前为止我发现很难做简单的事情.我现在正在努力的是过滤状态类型列表.StatusTypes模型是:
class StatusTypes(models.Model):
status = models.CharField(max_length=50)
type = models.IntegerField()
def __unicode__(self):
return self.status
class Meta:
db_table = u'status_types'
Run Code Online (Sandbox Code Playgroud)
在一个管理页面中,我需要所有结果,其中type = 0,而在另一个管理页面中,我需要所有结果,其中type = 1,所以我不能只在模型中限制它.我该怎么做呢?
编辑:我应该更清楚一点.我有一个模型"单元",它具有StatusTypes的外键.模型如下:
class StatusTypes(models.Model):
status = models.CharField(max_length=50)
type = models.IntegerField()
def __unicode__(self):
return self.status
class Meta:
db_table = u'status_types'
class Unit(models.Model):
name = models.CharField(unique=True, max_length=50)
status = models.ForeignKey(StatusTypes, db_column='status')
note = models.TextField()
date_added = models.DateTimeField()
def __unicode__(self):
return self.name
class Meta:
db_table = u'units'
Run Code Online (Sandbox Code Playgroud)
所以现在在单元模型的管理页面中,我想将状态限制为只有type = 1的那些.基于lazerscience响应,我尝试了以下代码:
from inv.inventory.models import Unit
from django.contrib import admin
class UnitAdmin(admin.ModelAdmin):
def queryset(self, request):
qs = super(UnitAdmin, self).queryset(request)
return qs.filter(type=0)
admin.site.register(Unit, UnitAdmin)
Run Code Online (Sandbox Code Playgroud)
但是,它根本没有改变选择框.我也尝试打印qs的值,没有输出到我的终端,所以我想知道我是否有一些如何调用queryset?
编辑2:我可能还不清楚我是否想要为单元模型的创建页面上的状态下拉列表进行过滤.
编辑:
事实证明 ModelAdmin.formfield_for_foreignkey 在这种情况下是正确的答案:http ://docs.djangoproject.com/en/dev/ref/contrib/admin/#django.contrib.admin.ModelAdmin.formfield_for_foreignkey
以前的答案:
看看ModelAdmin 的 list_filter 属性。这听起来更像是你想要的,因为它会创建一个很好的界面来过滤不同的标准,而不是随意限制你的查询集。
| 归档时间: |
|
| 查看次数: |
8551 次 |
| 最近记录: |