This is a simple way to exclude fields from being returned by a DRF serializer, without creating a separate serializer or installing another package. I needed to exclude a field when using the list action for a ModelViewSet, but because we’ll be utilizing the serializer’s context, it can be used no matter how you write your views.

Modifying the serializer

We’re going to override the serializer’s get_fields method to remove any fields we pass through the serializer’s context. I like to use a list of strings so that I can easily remove fields without making changes to the serializer later.

class WidgetSerializer(serializers.Serializer):
    name = SomeTypeOfField()
    parts = SomeTypeOfField()

    def get_fields(self):
        fields = super().get_fields()

        exclude_fields = self.context.get('exclude_fields', [])
        for field in exclude_fields:
            # providing a default prevents a KeyError
            # if the field does not exist
            fields.pop(field, default=None)

        return fields

You would use the same method with a ModelSerializer if you use those.

How to use

Let’s assume we have a field named parts in WidgetSerializer that we’d like to exclude from our response in a specific view. All we have to do is include the field name in the exclude_fields list passed through the serializer’s context.

class ListWidgets(APIView):
    def get(self, request, format=None):
        context = {
            'exclude_fields': [
                'parts'
            ]
        }

        widgets = Widget.objects.all()
        serializer = WidgetSerializer(widgets, many=True, context=context)

        # parts field will not be included
        return Response(serializer.data) 

If you are using DRF’s ViewSets (including ModelViewSet), you can override the get_serializer_context method instead. For example, if you only wanted to exclude fields in the list action, you could do the following:

class WidgetViewSet(viewsets.ModelViewSet):
    queryset = Widget.objects.all()
    serializer_class = WidgetSerializer

    def get_serializer_context(self):
        context = super().get_serializer_context()
        if self.action == 'list':
            context['exclude_fields'] = ['parts']
        return context

Conclusion

Hopefully this little guide helps you easily exclude fields from DRF serializers. I’ve only tested it with ModelViewSets and excluding fields in the list action, so it may not cover all cases. Feel free to contact me with corrections or suggestions on improvements.