最近,我在一个通用的题词系统中工作,帮助学生在班级或实验室注册。但是我对实验课中的ManyToManyField逻辑有问题。
from django.db import models
from django.contrib.auth.models import User
class Day(models.Model):
name = models.CharField(max_length=20, primary_key=True)
def __unicode__(self):
return u"%s" % self.name
class LabName(models.Model):
lab_name = models.CharField(max_length=50, primary_key=True)
class Meta:
verbose_name_plural = 'LabNames'
def __unicode__(self):
return u'%s' % self.lab_name
class Lab(models.Model):
name = models.ForeignKey(LabName)
start_hour = models.TimeField()
length = models.IntegerField(help_text="Given in minutes")
classDays = models.ManyToManyField(Day)
start_date = models.DateField()
finish_date = models.DateField()
max_cap = models.SmallIntegerField(help_text="Maximun number of students")
teacher = models.ForeignKey(User, related_name="Teachers")
students = models.ManyToManyField(User)
class Meta:
verbose_name_plural = 'Labs'
def __unicode__(self):
return u"%s %s" % (self.id, self.name)我更喜欢关联一个名为“same”的特定组(django.contrib.auth.models.Group),而不是所有用户,或者至少筛选和/或验证这个字段,只添加和查看学生,也可以对教师字段进行同样的操作。
更新1: --我刚刚注意到,也许我可以使用可选参数limit_choices_to过滤在某个组中的用户。
问题是:如何使用limit_choices_to参数仅显示“学生”组或“教师”组中的用户?

发布于 2011-03-14 23:12:11
啊,你看清楚多了。
我会重写{'id__in' : Group.objects.all().get(name='Teachers').user_set.all()}
致:{'groups__name' : 'Teachers' }
另外,如果您希望将您的管理功能与您的模型更多地分离开来(您知道admin最初完全在模型中吗?),您可以使用涉外钥匙,这无疑是将您的模型与管理垃圾隔离开来的好方法。
class MyModelAdmin(admin.ModelAdmin):
def formfield_for_foreignkey(self, db_field, request, **kwargs):
if db_field.name == "teacher":
kwargs["queryset"] = User.objects.filter(groups__name='Teacher')
if db_field.name == "students":
kwargs["queryset"] = User.objects.filter(groups__name='Student')
return super(MyModelAdmin, self).formfield_for_foreignkey(db_field, request, **kwargs)https://stackoverflow.com/questions/5304361
复制相似问题