react 导入excel

import XLSX from 'xlsx';
    importfile(e){
        const { onChange } = this.props;
        if(!e.target.files) return ;
        const file=e.target.files[0];
        var daochu = this.daochu;
        const values = this.props.form.getFieldsValue()
        const reader=new FileReader();
        reader.readAsBinaryString(file);
        reader.onload=function(e){
            const data=this.result;
            const wb=XLSX.read(data, {
                    type: 'binary'
                })
            const params = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]]);

            for(var i = 0; i<params.length; i++){
                params[i].Name = params[i].客户名称 ;
                delete params[i].客户名称 ;
                params[i].GenderName = params[i].性别 ;
                delete params[i].性别 ;
                params[i].Tel = params[i].联系电话 ;
                delete params[i].联系电话 ;
                params[i].WeChat = params[i].微信 ;
                delete params[i].微信 ;
                // params[i].qq = params[i].qq ;
                // delete params[i].qq ;
                params[i].StateValue = params[i].客户状态 ;
                delete params[i].客户状态 ;
                params[i].SourceValue = params[i].客户来源 ;
                delete params[i].客户来源 ;
                params[i].Address = params[i].通信地址 ;
                delete params[i].通信地址 ;
                params[i].ProvinceName = params[i].省 ;
                delete params[i].省 ;
                params[i].CityName = params[i].市 ;
                delete params[i].市 ;
                params[i].CountyName = params[i].区县 ;
                delete params[i].区县 ;
                params[i].EducationName = params[i].学历 ;
                delete params[i].学历 ;
                params[i].PoliticalOutlookName = params[i].政治面貌 ;
                delete params[i].政治面貌 ;
                params[i].CustomerLableValue = params[i].客户标签 ;
                delete params[i].客户标签 ;
                params[i].Remark = params[i].备注 ;
                delete params[i].备注 ;
            }

            request(`/api/C_Customer/ImportEnterpriseCustomer`, { method : 'POST' , body: params  })
                .then((req) => {
                    if(req.Success){
                        notification.success({
                            message: '导入成功',
                            description: req.Message
                        });
                        onChange(values)
                    }else{
                        if(req.ReturnData){
                            var data = [];
                            data = req.ReturnData;
                            Modal.error({
                                title: '导入失败',
                                content: req.Message,
                                okText:'下载文件',
                                maskClosable:true,
                                onOk: () => {
                                    daochu(data)
                                }
                            });
                        }else{
                            Modal.error({
                                title: '导入失败',
                                content: '必填数据不能为空',
                                okText:'知道了',
                                maskClosable:true,
                            });
                        }
                    }
                })  
        }
        this.input.value=null
    }
    daochu = (dataArr) => {
        const params = this.props.form.getFieldsValue();
        const param={
            ...params,
            StateKey:this.state.activeKey,
            SourceKey:params['SourceKey']==='null'?undefined:params['SourceKey']
        }
        const datas =  dataArr;
        const wopts = { bookType: 'xlsx', bookSST: false, type: 'binary' };//这里的数据是用来定义导出的格式类型
        const wb = { SheetNames: ['Sheet1'], Sheets: {}, Props: {} };
        const data=datas.map(item=>{
            return {
                '客户名称':item.Name,
                '联系电话':item.Tel,
                '客户标签':item.CustomerLableValue,
                '客户状态':item.StateValue,
                '距上次跟进(天)':item.OutTrackDay,
                '客户来源':item.SourceValue,
                '业务员':item.SalesmanName,
                '省份':item.ProvinceName,
                '城市':item.CityName,
                '区县':item.CountyName,
                '学历':item.EducationName,
                '性别':item.Gender == 0 ? '男':'女',
                '政治面貌':item.PoliticalOutlookName,
                'QQ':item.QQ,
                '类型':item.Type==1?'个人客户':'企业客户',
                '联系次数':item.ContactNum,
                '微信':item.WeChat,
                '错误信息': item.ErrorInfo
            }
        })
        wb.Sheets['Sheet1'] = XLSX.utils.json_to_sheet(data);//通过json_to_sheet转成单页(Sheet)数据
        this.saveAs(new Blob([this.s2ab(XLSX.write(wb, wopts))], { type: "application/octet-stream" }), "个人客户导出" + '.' + (wopts.bookType=="biff2"?"xls":wopts.bookType));
    }

    // 导出excel
    saveAs(obj, fileName){
        var tmpa = document.createElement("a");
        tmpa.download = fileName || "下载";
        tmpa.href = URL.createObjectURL(obj); //绑定a标签
        tmpa.click(); //模拟点击实现下载
        setTimeout(function () { //延时释放
            URL.revokeObjectURL(obj); //用URL.revokeObjectURL()来释放这个object URL
        }, 100);
    }

    s2ab(s) {
        if (typeof ArrayBuffer !== 'undefined') {
            var buf = new ArrayBuffer(s.length);
            var view = new Uint8Array(buf);
            for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
            return buf;
        } else {
            var buf = new Array(s.length);
            for (var i = 0; i != s.length; ++i) buf[i] = s.charCodeAt(i) & 0xFF;
            return buf;
        }
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值