python–Django Admin:按相关外键的值排序

python–Django Admin:按相关外键的值排序,第1张

概述我正在尝试按对象的相关外键集中的特定值对Django Admin列表页面进行排序.具体来说,在下面的代码中,我希望ContentAdmin视图显示按“Twitter Score”(名称为“Twitter”的Score对象)排序的所有内容对象的列表.在django应用程序中,我有以下模型:class Content(models.Model): bod

我正在尝试按对象的相关外键集中的特定值对Django admin列表页面进行排序.

具体来说,在下面的代码中,我希望Contentadmin视图显示按“Twitter score”(名称为“Twitter”的score对象)排序的所有内容对象的列表.

在django应用程序中,我有以下模型:

class Content(models.Model):    body = models.CharFIEld(max_length=564)    Title = models.CharFIEld(max_length=64) class score(models.Model):    name = models.CharFIEld(max_length=64)    score = models.IntegerFIEld()    content = models.ForeignKey('Content')

在admin.py中我有以下内容:

class Contentadmin(admin.Modeladmin):    List_display = ('Title','show_twitter_score',)    def show_twitter_score(self,obj):        twitter_score = obj.score_set.get(name='Twitter')        return 'Twitter: ' + str(twitter_score.score)

目标:Contentadmin的管理面板显示按“Twitter”分数排序的内容对象

感谢大家!

最佳答案我通过扩展Contentadmin类的get_queryset方法解决了这个问题.在那之后,只需要获得正确的ORM查询

def get_queryset(self,request):    qs = super(Contentadmin,self).get_queryset(request)    return qs.filter(score__name='Twitter').order_by('-score__score')

对于Django 1.5及更早版本,该方法是queryset.

def queryset(self,self).queryset(request)    return qs.filter(score__name='Twitter').order_by('-score__score')
总结

以上是内存溢出为你收集整理的python – Django Admin:按相关外键的值排序全部内容,希望文章能够帮你解决python – Django Admin:按相关外键的值排序所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/langs/1205550.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-04
下一篇2022-06-04

发表评论

登录后才能评论

评论列表(0条)

    保存