ExcelUtil.java 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package com.fdkankan.agent.util;
  2. import lombok.extern.slf4j.Slf4j;
  3. import org.apache.poi.hssf.usermodel.HSSFDateUtil;
  4. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  5. import org.apache.poi.ss.usermodel.*;
  6. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  7. import org.springframework.web.multipart.MultipartFile;
  8. import java.io.IOException;
  9. import java.io.InputStream;
  10. import java.text.SimpleDateFormat;
  11. import java.util.ArrayList;
  12. import java.util.Date;
  13. import java.util.HashMap;
  14. import java.util.List;
  15. @Slf4j
  16. public class ExcelUtil {
  17. public static List<HashMap<Integer,String>> getExcelRowList(MultipartFile multipartFile) throws IOException {
  18. //行List,也是最终要返回的List
  19. List<HashMap<Integer,String>> rowList=new ArrayList<>();
  20. Workbook workbook=getExcelWorkBook(multipartFile);
  21. Sheet sheet = workbook.getSheetAt(0);
  22. if (sheet == null) {
  23. throw new IOException("创建Sheet失败!");
  24. }
  25. //开始遍历行
  26. for (int i=0;i<= sheet.getLastRowNum();i++){
  27. Row row = sheet.getRow(i);
  28. //列List
  29. HashMap<Integer,String> map = new HashMap<>();
  30. if(row == null){
  31. rowList.add(map);
  32. continue;
  33. }
  34. //转换为List数组
  35. for (int cellNum=0;cellNum<= row.getLastCellNum();cellNum++){
  36. Cell cell = row.getCell(cellNum);
  37. if (cell != null && cell.getCellTypeEnum() != CellType.STRING && HSSFDateUtil.isCellDateFormatted(cell))
  38. {
  39. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  40. Date date = HSSFDateUtil.getJavaDate(cell.getNumericCellValue());
  41. String value = sdf.format(date);
  42. map.put(cellNum,value);
  43. continue;
  44. }
  45. if(cell != null){
  46. String value = fommartNum(cell.toString().trim());
  47. map.put(cellNum,value);
  48. }
  49. }
  50. rowList.add(map);
  51. }
  52. return rowList;
  53. }
  54. private static Workbook getExcelWorkBook(InputStream inputStream) throws IOException {
  55. return new XSSFWorkbook(inputStream);
  56. }
  57. private static String fommartNum(String value){
  58. try {
  59. if(isNumeric2(value) && value.contains(".")){
  60. log.info("fommartNum:{}",value);
  61. return Double.valueOf(value).intValue() +"";
  62. }
  63. }catch (Exception e){
  64. return value;
  65. }
  66. return value;
  67. }
  68. public static boolean isNumeric2(String str) {
  69. return str != null && str.matches("-?\\d+(\\.\\d+)?");
  70. }
  71. public static List<HashMap<Integer,String>> getExcelRowList(InputStream inputStream) throws IOException {
  72. //行List,也是最终要返回的List
  73. List<HashMap<Integer,String>> rowList=new ArrayList<>();
  74. Workbook workbook=getExcelWorkBook(inputStream);
  75. Sheet sheet = workbook.getSheetAt(0);
  76. if (sheet == null) {
  77. throw new IOException("创建Sheet失败!");
  78. }
  79. //开始遍历行
  80. for (int i=0;i<= sheet.getLastRowNum();i++){
  81. Row row = sheet.getRow(i);
  82. //列List
  83. HashMap<Integer,String> map = new HashMap<>();
  84. if(row == null){
  85. rowList.add(map);
  86. continue;
  87. }
  88. //转换为List数组
  89. for (int cellNum=0;cellNum<= row.getLastCellNum();cellNum++){
  90. Cell cell = row.getCell(cellNum);
  91. if (cell != null && cell.getCellTypeEnum() != CellType.STRING && HSSFDateUtil.isCellDateFormatted(cell))
  92. {
  93. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  94. Date date = HSSFDateUtil.getJavaDate(cell.getNumericCellValue());
  95. String value = sdf.format(date);
  96. map.put(cellNum,value);
  97. continue;
  98. }
  99. if(cell != null){
  100. String stringCellValue = cell.getStringCellValue();
  101. log.info(stringCellValue);
  102. String value = fommartNum(cell.toString().trim());
  103. map.put(cellNum,value);
  104. }
  105. }
  106. rowList.add(map);
  107. }
  108. return rowList;
  109. }
  110. private static Workbook getExcelWorkBook(MultipartFile multipartFile) throws IOException {
  111. InputStream inputStream=multipartFile.getInputStream();
  112. String originalFileName=multipartFile.getOriginalFilename();
  113. assert originalFileName != null;
  114. String fileType=originalFileName.substring(originalFileName.lastIndexOf(".")+1);
  115. if (fileType.equalsIgnoreCase("xls")) {
  116. //xls格式
  117. return new HSSFWorkbook(inputStream);
  118. } else {
  119. //xlsx格式
  120. return new XSSFWorkbook(inputStream);
  121. }
  122. }
  123. }