导入excel内容

摘要:

MultipartFile工具类:

  1. MultipartFile是SpringMVC提供简化上传操作的工具类。
  2. 在不使用框架之前,都是使用原生的HttpServletRequest来接收上传的数据,文件是以二进制流传递到后端的,然后需要我们自己转换为File类,非常麻烦。使用了MultipartFile工具类之后,我们对文件上传的操作就简便许多了。
  3. 以下是MultipartFile工具类全部的接口方法。
方法名 返回值 作用
getContentType() String 在取文件MIME类型
getlnputStream() InputStream 获取文件流
getName() String 获取 form 表单中文件组件的名字
getOriginalFilename() String 获取上传文件件的原名
getSize() long 获取文件的大小,单位为byte
isEmpty() boolean 是否为空
transferTo(File dest) void 将数据保存到一个目标文件中

1.定义一个枚举类 

用来遍历excel每一列

package com.amarsoft.lease.commerce.constant;

public enum CmceWarrantyInfoColumnEnum {
    LEASEHOLD_NO(0, "租赁物编号", "leaseholdNo"),
    INSURANCE_COMPANY(1, "保险公司", "insuranceCompany"),
    SLIP_NO(2, "保单号", "slipNo"),
    INSURE_START_DATE(3, "保险起始日", "insureStartDate"),
    INSURE_END_DATE(4, "保险到期日", "insureEndDate"),
    IS_SURRENDER(5, "是否为退保单", "isSurrender");


    private int columnNum;
    private String columnName;
    private String columnKey;

    CmceWarrantyInfoColumnEnum(int columnNum, String columnName, String columnKey) {
        this.columnNum = columnNum;
        this.columnName = columnName;
        this.columnKey = columnKey;
    }

    public int getColumnNum() {
        return columnNum;
    }

    public void setColumnNum(int columnNum) {
        this.columnNum = columnNum;
    }

    public String getColumnName() {
        return columnName;
    }

    public void setColumnName(String columnName) {
        this.columnName = columnName;
    }

    public String getColumnKey() {
        return columnKey;
    }

    public void setColumnKey(String columnKey) {
        this.columnKey = columnKey;
    }

    /**
     * 获取列名
     * @param columnNum
     * @return
     */
    public static CmceWarrantyInfoColumnEnum getByColumnNum(int columnNum) {
        CmceWarrantyInfoColumnEnum[] columnEnums = CmceWarrantyInfoColumnEnum.values();
        for (CmceWarrantyInfoColumnEnum columnEnum : columnEnums) {
            if(columnEnum.getColumnNum() == columnNum) return columnEnum;
        }
        return null;
    }
}

2.定义接口

2.1:如果接入的接口是HttpServletRequest 

  1. // 转型为MultipartHttpRequest:   
  2.         MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;  
  3.         // 获得文件:   
  4.         MultipartFile file = multipartRequest.getFile(" file ");   
  5.         // 获得文件名:   
  6.         String filename = file.getOriginalFilename();   
  7.         // 获得输入流:   
  8.         InputStream input = file.getInputStream();   
  9.         // 写入文件   
  10.         File source = new File(localfileName.toString());   
  11.         multipartFile.transferTo(source);  

2.2:直接使用  MultipartHttpServletRequest

@PostMapping("/uploadInsureInfo")
    @Transactional
    public ResultResponse<T> uploadInsureInfo(MultipartHttpServletRequest request) {
        List<MultipartFile> files = request.getFiles("file");
        MultipartFile file = null;
        InputStream inputStream = null;
        Date date = new Date();
        for (int i = 0; i < files.size(); i++) {
            file = files.get(i);
            if (!file.isEmpty()) {
                try {
                    inputStream = file.getInputStream();//路劲
                    Workbook workbook = ExcelUtils.openWorkbook(inputStream);
                    Sheet sheet = workbook.cloneSheet(0);
                    Row firstRow = sheet.getRow(0);//获取每一行的结果
                    if (Objects.isNull(firstRow)) {
                        return ResultResponse.error("导入数据为空或模板不正确, 请检查文件重新上传");
                    }
                    //获取总行数、总列数
                    int rowSum = sheet.getLastRowNum() + 1;
                    int columnSum = firstRow.getLastCellNum() + 1;
                    //校验列名是否正确
                    for (int k = 0; k < 6; k++) {
                        Cell name = firstRow.getCell(k);
                        ValueObject nameValueObject = Objects.isNull(name) ? ValueObject.valueOf(null) : new ValueObject(ExcelCellHelper.getCellValue(name));
                        String strName = nameValueObject.strValue();
                        if (strName.endsWith("*")) {
                            strName = strName.substring(0, strName.length() - 1);
                        }
                        if (!Objects.requireNonNull(CmceWarrantyInfoColumnEnum.getByColumnNum(k)).getColumnName().equals(strName)) {
                            return ResultResponse.error("导入数据为空或模板不正确, 请检查文件重新上传");
                        }
                    }
                    //校验每一行结果是否正确
                    a:
                    for (int i1 = 1; i1 < rowSum; i1++) {
                        /**
                         * getRow 获取行     getCell  获取列
                         */
                        Row currentRow = sheet.getRow(i1);
                        if (Objects.isNull(currentRow)) continue;
                        CmceWarrantyInfoPO cmceWarrantyInfoPO = new CmceWarrantyInfoPO();//创建每一行落库的保单数据
                       
  • 10
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值