admin 管理员组文章数量: 887007
Django后端开发学习笔记:记录一些小问题
目录
- 常见问题参考
- 零散知识点
- 1. DRF获取参数的方式
- 2. DateTimeField
- 3. DRF中的action
常见问题参考
这里记录下以后可能会用上的东西
【1】Shell脚本启动django 的runserver
【2】Django rest framework自定义返回数据格式
【3】django restframework 实现单个和群体增删改查
【4】Django REST Framework中把DatetimeField转换为时间戳
【5】Django的ORM中如何判断查询结果是否为空,判断django中的orm为空
【6】Django–自定义Serializer序列化字段,动态改变field参数
零散知识点
1. DRF获取参数的方式
# 例如url
# url(r'^demo/(?P<word>.*)/$', DemoView.as_view())
# 在类视图中获取参数
# url:http://127.0.0.1:8000/demo/aaa/?bbb=bbb&ccc=ccc&ccc=CCC
# form:{"body":"body"}
# JSON:{"body":"body"}
class DemoView(APIView):def post(self, request, aaa):aaa = aaa # 获取url路径中的参数bbb_str = request.query_params.get('bbb') # 获取一个查询字符串的参数ccc_list = request.query_params.getlist('ccc') # 获取多个查询字符串参数# 请求体中的参数# 如果通过form表单传递,获取出来是QueryDict,通过.dict()转换成python的字典form_body = request.data# 如果通过JSON传递,获取出来就是字典,例如{'body':'body'}# json_body = request.dataprint(aaa)print(bbb_str)print(ccc_list)print(form_body.dict())# print(json_body)return Response({'message': 'OK'})
结果
aaa
bbb
['ccc', 'CCC']
{'body': 'body'}
URL路径参数/查询字符串不区分请求方式,GET/POST/PUT等都一样
serializer中获取参数
# view
class DemoView(GenericAPIView):serializer_class = DemoSerializerdef post(self, request, aaa):serializer = self.get_serializer(data=request.query_params)serializer.is_valid(raise_exception=True)return Response({'message': 'OK'})# serializer
class DemoSerializer(serializers.Serializer):bbb = serializers.CharField()ccc = serializers.ListField() # Listdef validate(self, attrs):aaa = self.context['view'].kwargs.get('aaa') # 获取路径参数bbb = attrs['bbb'] # 获取查询字符串ccc = attrs['ccc'] # 获取以多个key相同的查询字符串# 获取当前登陆的对象,需要根据场景进行使用# user = self.context['request'].userprint(aaa)print(bbb)print(ccc)return attrs
2. DateTimeField
created = models.DateTimeField(auto_now_add=True)
auto_now=Ture
,字段保存时会自动保存当前时间,但要注意每次对其实例执行save()的时候都会将当前时间保存,也就是不能再手动给它存非当前时间的值。auto_now_add=True
,字段在实例第一次保存的时候会保存当前时间,不管你在这里是否对其赋值。但是之后的save()是可以手动赋值的。也就是新实例化一个model,想手动存其他时间,就需要对该实例save()之后赋值然后再save()。
3. DRF中的action
1.作用:将ViewSet方法标记为可路由操作。@action装饰器函数将被赋予“mapping”属性,可用于添加其他基于方法的行为的“方法映射器”。
2.@action(methods=None, detail=None, url_path=None, url_name=None, **kwargs)
- methods:此操作响应的HTTP方法名称的列表。默认为“get”。
- detail:必需。确定此操作是否适用于实例/细节请求或集合/列表请求。 url_path:定义此操作的url段。默认为装饰的方法的名称。
- url_name:定义此操作的内部(reverse)url名称。默认为用下划线修饰的方法的名称替换为破折号。
- kwargs:要在视图上设置的其他属性。这个可以用重写viewset level*\u
- classes设置,相当于“@renderer_classes”等修饰符如何为函数工作-基于API视图。
from rest_framework.decorators import action@action(methods=['get'], detail=False)
def get_user_list(self, request):return Response(res, status=status.HTTP_200_OK)@action(methods=['get'], detail=True)def get_user_detail(self, request, pk):return Response(data, status=status.HTTP_200_OK)3.访问路由
xxx/get_user_list
xxx/pk/get_user_detail
本文标签: Django后端开发学习笔记记录一些小问题
版权声明:本文标题:Django后端开发学习笔记:记录一些小问题 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.freenas.com.cn/jishu/1732361192h1535264.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论