django-restframework对上传excl文件的读取处理

在继承mixins.CreateModelMixin后POST接口上传数据时的处理顺序是view–>serializers–>model,在view中可以通过重写crete方法直接读取请求中附带的excl文件后赋值其他字段并插入model

    def create(self, request, *args, **kwargs):
        f = request.FILES.get('excl_flie')
        if f:
            wb = xlrd.open_workbook(filename=None, file_contents=f.read())
            table = wb.sheets()[0]
            rows = table.nrows
            for i in range(1, rows):
                serializer = self.get_serializer(data=request.data)
                serializer.is_valid(raise_exception=True)
                row = table.row_values(i)
                serializer.validated_data['ba_item_no'] = row[0]
                serializer.validated_data['ba_item_all'] = Production.objects.filter(code=row[0])[0]
                serializer.validated_data['suplier'] = row[1]
                serializer.validated_data['suplier_all'] = Supplier.o
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值