如何返回特定字段queryset DRF



我想创建一个自定义查询集类,该类返回不同的字段来预定义两个案例。

  1. DateField大于今天
  2. 当它比今天少的时候

如果大于,则返回所有字段,否则仅返回date_to_openpost_name字段。

views.py

class GroupDetail(generics.RetrieveAPIView):
serializer_class = serializers.GroupDetailsSerializer
permission_classes = (IsAuthenticated, )
def greater(self):
return models.Group.objects.filter(shared_to=self.request.user, 
date_to_open__gt=timezone.now()).exists()

def get_queryset(self, *args, **kwargs):
if self.greater():
query_set = models.Group.objects.filter(shared_to=self.request.user, 
date_to_open__gt=timezone.now())
else:
query_set = SPECIFIC FIELDS
return query_set

serializers.py

class GroupDetailsSerializer(serializers.ModelSerializer):
owner = serializers.ReadOnlyField(source='owner.name')
images = GroupImageSerializer(many=True, read_only=True)
shared_to = serializers.SlugRelatedField(queryset=models.UserProfile.objects.all(), 
slug_field='name', many=True)
class Meta:
model = models.Group
fields = ('id', 'group_name', 'owner', 'group_text', 'created_on', 'date_to_open', 'shared_to', 
'images', )

好的。感谢@ArakkalAbu的评论,我刚刚覆盖了get_serializer_class()

views.py

class GroupDetail(generics.RetrieveAPIView):
queryset = models.Group.objects.all()
serializer_class = serializers.GroupDetailsSerializer
permission_classes = (IsAuthenticated, )
def greater(self):
return models.Group.objects.filter(shared_to=self.request.user, date_to_open__gt=timezone.now()).exists()

def get_serializer_class(self):
if self.greater():
return serializers.GroupDetailsSerializer
else:
return serializers.ClosedGroupDetailsSerializer

您可以继续使用相同的逻辑,并使用values_list从查询集中返回特定的值。返回的值也是一个查询集

def get_queryset(self, *args, **kwargs):
if self.greater():
return models.Group.objects.filter(shared_to=self.request.user, date_to_open__gt=timezone.now())
else:
return models.Group.objects.filter(shared_to=self.request.user, date_to_open__lt=timezone.now()).values_list('date_to_open', 'post_name' , flat = True)

最新更新