当前位置: 首页 > news >正文

POI导入时相关的EXCEL校验

一、单元格值非空校验

    public static Boolean poiCellIsNull(Cell cell){if (Objects.isNull(cell)){return true;}else {if (cell.getCellType() == Cell.CELL_TYPE_BLANK){return true;}else if (cell.getCellType()==Cell.CELL_TYPE_STRING && cell.getStringCellValue().trim().isEmpty()){return true;}else {return false;}}}

二、获取EXCEL的 sheet && 单元格值类型是否合规校验

注-参数说明:

        第一个是mutiple获取的文件字节流,第二个参数是文件类型(xls、xlsx),

        第三个参数是 数据行数的开始索引,第四个参数是数据列数的开始索引,

        第五个参数是不为空的列数字符串,例如:"1,2,3"==》表示第1列、第二列、第三列所属单元格的值不能为空

        第六个参数是一个Map<Integer,Integer>类型,表示第几列单元格的值类型应该为xxx;枚举值是开始的前三行,分别是字符串类型(0),数字类型(1),日期类型(2)

        例如:map.put(1,EXCEL_STRING); ===》表示第一列所属单元格的值应该为字符类型。

    public static final Integer EXCEL_STRING = 0;public static final Integer EXCEL_NUMBER = 1;public static final Integer EXCEL_DATE = 2;public static Sheet getExcelDataSingleSheet(InputStream inputStream,String fileType,Integer rowStartIndex,Integer culStartIndex, String notNullStr,Map<Integer,Integer> classJudgeMap) throws IOException {Workbook workbook = null;if ("xls".equals(fileType)){workbook = new HSSFWorkbook(inputStream);}else if ("xlsx".equals(fileType)){workbook = new XSSFWorkbook(inputStream);}else {throw new IOException("文件类型不存在,请检查!");}//获取第一个sheet页Sheet sheet = workbook.getSheetAt(0);Row rowTitle = null;if (rowStartIndex==1){rowTitle = sheet.getRow(0);}int lastRowNum = sheet.getLastRowNum();for (int i = rowStartIndex; i <= lastRowNum; i++) {Row row = sheet.getRow(i);int lastCellNum = (int)row.getLastCellNum();for (int j = culStartIndex; j < lastCellNum; j++) {Cell cell = row.getCell(j);if (!notNullStr.isEmpty() && notNullStr.contains(String.valueOf(j)) && poiCellIsNull(cell)){StringBuffer stringBuffer = new StringBuffer();stringBuffer.append(String.format("第%d行,第%d列",i+1,j+1));if (rowStartIndex==1){String title = rowTitle.getCell(j).getStringCellValue();stringBuffer.append(String.format("【%s】",title));}stringBuffer.append("不准为空");throw new IOException(stringBuffer.toString());}StringBuffer errorMessage = new StringBuffer();try {if (classJudgeMap.containsKey(j)){switch (classJudgeMap.get(j)){case 0:errorMessage.append(String.format("第%d行,第%d列",i+1,j+1));errorMessage.append(String.format("【%s】",rowTitle.getCell(j).getStringCellValue()));errorMessage.append("应为字符类型");String stringCellValue = cell.getStringCellValue();break;case 1:errorMessage.append(String.format("第%d行,第%d列",i+1,j+1));errorMessage.append(String.format("【%s】",rowTitle.getCell(j).getStringCellValue()));errorMessage.append("应为数值类型");double numericCellValue = cell.getNumericCellValue();break;case 2:errorMessage.append(String.format("第%d行,第%d列",i+1,j+1));errorMessage.append(String.format("【%s】",rowTitle.getCell(j).getStringCellValue()));errorMessage.append("应为日期类型");Date dateCellValue = cell.getDateCellValue();break;default:break;}}}catch (IllegalStateException e){throw new IOException(errorMessage.toString());}catch (Exception e){e.printStackTrace();}}}return sheet;}

http://www.xdnf.cn/news/1279873.html

相关文章:

  • Spring Boot Excel数据导入数据库实现详解
  • 缓存的三大问题分析与解决
  • Flink + Hologres构建实时数仓
  • MSE ZooKeeper:Flink高可用架构的企业级选择
  • 容器之王--Docker的安全优化详解及演练
  • 在Mac 上生成GitLab 的SSH 密钥并将其添加到GitLab
  • Django Request 与 DRF Request 的区别
  • (Arxiv-2025)Phantom:通过跨模态对齐实现主体一致性视频生成
  • 什么情况下会导致日本服务器变慢?解决办法
  • 第2节 大模型分布式推理架构设计原则
  • AIStarter修复macOS 15兼容问题:跨平台AI项目管理新体验
  • MySQL权限管理和MySQL备份
  • 大模型落地实践:从技术重构到行业变革的双重突破
  • C/C++练习面试题
  • Selenium动态元素定位
  • 【运维进阶】WEB 服务器
  • 学习观察和行动:机器人操作中任务-觉察的视图规划
  • docker安装searxng
  • C语言如何安全的进行字符串拷贝
  • 云原生环境 Prometheus 企业级监控实战
  • Centos 用http ftp搭建本地yum源 保姆级教程
  • QML开发:动画元素
  • 企业高性能web服务器Nginx的详细部署(实战篇)
  • [4.2-2] NCCL新版本的register如何实现的?
  • ResponseBodyAdvice是什么?
  • ChatML vs Harmony:深度解析OpenAI全新对话结构格式的变化
  • ARM基础概念 day51
  • Redis应⽤-缓存与分布式锁
  • Vue3从入门到精通:3.1 性能优化策略深度解析
  • 基于SpringBoot+Uniapp的血压监控小程序(Echarts图形化分析)