场景:上传一个源数据Excel文件,然后根据数据处理生成另外一个Excel文件并支持下载
Django:
1.首先在Django的settings.py文件中增加配置
MEDIA_URL = '/media/' MEDIA_ROOT = os.path.join(BASE_DIR, 'media')

2.项目的urls.py中增加
url(r'^media/(?P<path>.*)$', serve, {"document_root": MEDIA_ROOT}),
 

3.在APP的models.py中内容
# 文件模型
class TestTrafficFileModel(models.Model):
    id = models.AutoField(verbose_name='id主键', primary_key=True, help_text='id主键')
    upload_name = models.CharField(max_length=50, verbose_name='源数据文件名称', help_text='源数据文件名称')
    upload_file = models.FileField(upload_to='uploads/', verbose_name='上传文件路径', help_text='上传文件路径')
    handle_name = models.CharField(max_length=50, verbose_name='处理后文件名称', help_text='处理后文件名称')
    handle_file = models.FileField(upload_to='uploads/', verbose_name='数据处理文件路径', help_text='数据处理文件路径')
    upload_time = models.DateTimeField(auto_now_add=True, verbose_name='上传时间', help_text='上传时间')
    update_time = models.DateTimeField(auto_now=True, verbose_name='更新时间', help_text='更新时间')
    class Meta:
        db_table = 'test_traffic_files_storage'
        verbose_name = '测试工具文件存放表'
        verbose_name_plural = verbose_name
        ordering = ('id',)
    def __str__(self):
        return self.name
 
4.在APP的serializers.py中的内容
class FilesSerializer(serializers.ModelSerializer):
    sheet_name = serializers.CharField(label='sheet表名', read_only=True)
    class Meta:
        model = models.TestTrafficFileModel
        fields = '__all__'
        extra_kwargs = {
            "id": {
                "read_only": True
            },
            "handle_file": {
                "read_only": True
            },
            "handle_name": {
                "read_only": True
            },
            "upload_time": {
                "format": "%Y-%m-%d %H:%M:%S"
            },
            "update_time": {
                "format": "%Y-%m-%d %H:%M:%S"
            },
        }
    def create(self, validated_data):
        instance = super(FilesSerializer, self).create(validated_data)
        # 上传源数据内的sheet表名
        instance.sheet_name = instance.upload_name.replace('_', ' ').split('.')[0]
        # 因上传后,实际表名与上传表名有区别,需将上传表名设置成实际表名
        instance.upload_name = str(instance.upload_file).split('/')[1]
        return instance 
5.在APP的views.py中的内容
class DataHandleViewSet(ModelViewSet):
    queryset = models.TestTrafficFileModel.objects.all()
    serializer_class = serializers.FilesSerializer
    ordering_fields = ['id']
    def create(self, request, *args, **kwargs):
        response = super().create(request, *args, **kwargs)
        log.info(response)
        id = response.data.get('id')
        sheet_name = response.data.get('sheet_name')
        excel_name = response.data.get('upload_name')
        # 对数据做处理后返回表的title和表源数据列表
        res = handle_excel_data(file=f'media/uploads/{excel_name}',sheet_name=sheet_name)
        # 生成新的Excel后返回新的表名
        handle_file = genttle_sm_analysis_excel(*res)
        # 获取新表文件名
        handle_name = handle_file.split('/')[1]
        # 将新表文件名和文件地址写入数据库
        self.get_queryset().filter(id=id).update(handle_name=handle_name,handle_file=handle_file)
        return response 
 
Vue前端methods内容
// 下载文件
cellClick({ row, column, cell, event }) {
if (column.label === '数据处理后的文件') {
window.open(row.handle_file)
}
},
// 上传文件
uploadFile() {
const uploadForm = new FormData() // 一个formdata
const files = this.$refs.upload.$refs.uploadExcelForm.uploadFiles[0].raw // 获取文件数据
const name = this.$refs.upload.$refs.uploadExcelForm.uploadFiles[0].name // 获取文件数据
uploadForm.append('upload_file', files)
uploadForm.append('upload_name', name)
this.loading = true
file_uploads(uploadForm).then(res => {
this.loading = false
this.uploadVisible = false
this.getTableData()
this.$message.success('操作成功!')
}).catch(res => {
this.loading = false
this.$message.warning(res.data)
})
},
















