这是我的serilizer类:
class RankNewsChannelSerializers(serializers.ModelSerializer):
class Meta:
model = News_Channel
fields = ('id', 'name','total_star', 'total_user')
这是我的观点:
class NewsChannelRankApi(ListAPIView):
queryset = News_Channel.objects.order_by('-total_star').all()
serializer_class = RankNewsChannelSerializers
我得到的响应是基于total_stars
进行排序的,如下所示:
[
{
"id": 9,
"name": "The Hindu",
"total_star": 36,
"total_user": 5
},
{
"id": 1,
"name": "NDTV",
"total_star": 36,
"total_user": 5
},
{
"id": 10,
"name": "Firstpost",
"total_star": 35,
"total_user": 6
},
{
"id": 14,
"name": "DD News",
"total_star": 25,
"total_user": 4
}
]
但我需要按total_star/total_user
对响应进行排序。就像这是我的无效方法,但它会让你大致了解我想要实现的目标。
class NewsChannelRankApi(ListAPIView):
queryset = News_Channel.objects.order_by('-total_star/total_user').all()
serializer_class = RankNewsChannelSerializers
如果有什么办法的话,请帮帮我?
发布于 2019-05-30 19:08:28
您可以添加一个具有所需值的字段,然后按该值排序。此外,您也不需要.all()
queryset = News_Channel.objects \
.annotate(stars_per_user=F('total_star')/F('total_user')) \
.order_by('-stars_per_user')
https://stackoverflow.com/questions/56384210
复制相似问题