7

Django Admin インターフェイスを使用して、HTML select multiple 内のオブジェクトが特定の順序 (アルファベット順を優先) でソートされるようにするにはどうすればよいですか? 問題は、CD、歌、歌手の 3 つのモデルがあることです。CD 管理ダッシュボードの 1 つで、Song は CD にインラインであり、Singer は、ソートしたい多数のフィールドです。

私のmodel.pyファイル:

class CD(models.Model):

    cd_name = models.CharField("CD Name",max_length=50)
    date = models.DateField("CD Release Date")
    photo = models.ImageField("CD Cover",blank=True,upload_to='covers')
    singers = models.ManyToManyField(Singer,blank=True,null=True) 

    def __unicode__(self):
        return self.cd_name

class Song(models.Model):

    cid = models.ForeignKey(CD)
    track_num = models.PositiveIntegerField("Track Number",max_length=2) 
    song_name = models.CharField("Song Name",max_length=50)
    soloists = models.ManyToManyField(Singer,blank=True,null=True) 
    stream_url = models.URLField("Stream URL", blank=True)

    def __unicode__(self):
        return self.song_name

class Singer(models.Model): (not relevent)

私のadmin.pyファイル:

class SongInline(admin.TabularInline):
    model = Song
    extra = 0

class CDAdmin(admin.ModelAdmin):

    list_display = ('cd_name', 'date')

    inlines = [
        SongInline,
    ]

admin.site.register(CD, CDAdmin)
4

1 に答える 1

2

formfield_for_manytomany

class SongInline(admin.TabularInline):
    model = Song
    extra = 0

    def formfield_for_manytomany(self, db_field, request, **kwargs):
            if db_field.name == "soloists":
                kwargs["queryset"] = Singer.objects.order_by('last_name')
            return super(SongInline, self).formfield_for_manytomany(db_field, request, **kwargs)

これは「ModelAdminの順序付け」に関する特定の質問に答えますが、あなたの場合は、モデルorderingモデルのメタクラスオプションを使用して、m2mモデルのデフォルトの順序付けを定義するだけです。

http://docs.djangoproject.com/en/dev/ref/models/options/#ordering

class Singer(models.Model):
    # my model
    class Meta:
        ordering = ['name'] # your select box will respect this as well.
于 2011-04-24T22:54:49.530 に答える