POI导入

try {
//创建url
URL url = new URL(fileUrl);
//创建URl连接
URLConnection connection = url.openConnection();
//连接远程服务器
connection.connect();
XSSFWorkbook workbook = null;
try {
workbook = new XSSFWorkbook(connection.getInputStream());
// 读取第一页
XSSFSheet sheet = workbook.getSheetAt(0);
//获取有效行数
int lastRowNum = sheet.getLastRowNum();

//可以在这里对模板中的第一行标题 进行判断 是否是原先导出的模板

            //第一行不做为数据
            for (int i = 1; i <=lastRowNum; i++) {
                XSSFRow row = sheet.getRow(i);

                short lastCellNum = row.getLastCellNum();
                List<String> list=new ArrayList<>();
                for (int j = 0; j <lastCellNum ; j++) {
                    XSSFCell cell = row.getCell(j);
                    //强制把内容设置为字符串,再读取
                    cell.setCellType(Cell.CELL_TYPE_STRING);
                    //判断单元格类型的方法
                    String cellValue = pdType(cell);
                    list.add(cellValue);
                }
                //把数据存到数据库方法
                saveData(list);
            }
                workbook.close();
        } catch (Exception e) {
            e.printStackTrace();
        }finally {
            if (workbook != null) {
                workbook.close();
            }
        }

        return RestResponse.success();
    } catch (IOException e) {
        e.printStackTrace();
        return RestResponse.failure("导入失败");
    }
}

//判断单元格类型
public String pdType(XSSFCell cell){
    String cellValue = "";
    switch (cell.getCellType()) {
        case XSSFCell.CELL_TYPE_STRING://字符串类型
            cellValue = cell.getStringCellValue();
            break;
        case XSSFCell.CELL_TYPE_NUMERIC: //数值类型
            cellValue = String.valueOf(cell.getNumericCellValue());
            break;
        default:
            break;
    }
    return cellValue;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值