我想接收带有查询参数(如果存在)的获取查询和过滤数据集。我目前正在使用下面列出的愚蠢方法。在这种情况下,我不喜欢它没有检查日期是否实际上可以被解析。在另一种方法中,我可能只想接收可以解析为 int 的数字字符串。有没有一些很酷的Pythonic方法可以做到这一点,而无需编写一堆样板代码?
class TrackList(APIView):
@token_required
def get(self, request, pk, **kwargs):
# read query params
date_from = self.request.query_params.get('date_from')
date_to = self.request.query_params.get('date_to')
# if present then filter
if date_from and date_to:
points = Track.objects.filter(user_id=pk, date__range=[date_from, date_to])
# otherwise don't filter
else:
points = Track.objects.filter(user_id=pk)
points.order_by('date')
serializer = TrackListSerializer(points, many=True)
return Response(serializer.data, status=status.HTTP_200_OK)
Run Code Online (Sandbox Code Playgroud)
UPD:问题实际上不是关于dateutil.parser,而是关于通用查询参数解析器。也许我应该使用 Django Rest 序列化器?
我认为对于上述情况我们必须使用该包django-filter。要安装它pip install django-filter,最好使用通用视图。
添加下面的代码settings.py
REST_FRAMEWORK = {
'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',)
}
Run Code Online (Sandbox Code Playgroud)
使用视图和过滤器
from rest_framework import generics
from django_filters import rest_framework as filters
from myapp import Track
class TrackFilter(filters.FilterSet):
from_date = filters.DateFilter(field_name="date", lookup_expr='gte')
to_date = filters.DateFilter(field_name="date", lookup_expr='lte')
class Meta:
model = Track
fields = ['date']
class TrackListAPIView(generics.ListAPIView):
queryset = Track.objects.all()
serializer_class = TrackListSerializer
filter_backends = (DjangoFilterBackend,) # optional
filterset_class = TrackFilter
Run Code Online (Sandbox Code Playgroud)
用法:
http://localhost:8000/api/endpoint/?from_date=2018-01-01&to_date=2018-01-18
Run Code Online (Sandbox Code Playgroud)
参考资料:
http://django-filter.readthedocs.io/en/latest/ref/filterset.html
http://www.django-rest-framework.org/api-guide/filtering/
| 归档时间: |
|
| 查看次数: |
5708 次 |
| 最近记录: |