From 6f1203d1cf895efc473fade3ab049fc30d92c618 Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期三, 26 三月 2025 16:48:23 +0800
Subject: [PATCH] 优化

---
 server/system_service/src/main/java/com/doumee/core/annotation/excel/ExcelImporter.java |   43 +++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 41 insertions(+), 2 deletions(-)

diff --git a/server/system_service/src/main/java/com/doumee/core/annotation/excel/ExcelImporter.java b/server/system_service/src/main/java/com/doumee/core/annotation/excel/ExcelImporter.java
index 8f98162..f8f067c 100644
--- a/server/system_service/src/main/java/com/doumee/core/annotation/excel/ExcelImporter.java
+++ b/server/system_service/src/main/java/com/doumee/core/annotation/excel/ExcelImporter.java
@@ -38,6 +38,10 @@
      * 鏍囬琛屽彿
      */
     private int headerNum;
+    /**
+     * 鏍囬琛屽彿
+     */
+    private CellType changeType;
 
     /**
      * 鏋勯�犲嚱鏁�
@@ -101,6 +105,18 @@
         throws InvalidFormatException, IOException {
         this(multipartFile.getOriginalFilename(), multipartFile.getInputStream(), headerNum, sheetIndex);
     }
+    /**
+     * 鏋勯�犲嚱鏁� (閲嶈)
+     * @param--file 瀵煎叆鏂囦欢瀵硅薄
+     * @param headerNum 鏍囬琛屽彿锛屾暟鎹鍙�=鏍囬琛屽彿+1
+     * @param sheetIndex 宸ヤ綔琛ㄧ紪鍙�
+     * @throws InvalidFormatException
+     * @throws IOException
+     */
+    public ExcelImporter(MultipartFile multipartFile, int headerNum, int sheetIndex, CellType cellType)
+        throws InvalidFormatException, IOException {
+        this(multipartFile.getOriginalFilename(), multipartFile.getInputStream(), headerNum, sheetIndex,cellType);
+    }
 
     /**
      * 鏋勯�犲嚱鏁� 锛堬級
@@ -128,6 +144,27 @@
         this.headerNum = headerNum;
         log.debug("Initialize success.");
     }
+    public ExcelImporter(String fileName, InputStream in, int headerNum, int sheetIndex,CellType cellType)
+        throws InvalidFormatException, IOException {
+        if (StringUtils.isBlank(fileName)){
+            throw new RuntimeException("瀵煎叆鏂囨。涓虹┖!");
+        }else if(fileName.toLowerCase().endsWith("xls")){
+            this.wb = new HSSFWorkbook(in);
+        }else if(fileName.toLowerCase().endsWith("xlsx")){
+            this.wb = new XSSFWorkbook(in);
+        }else{
+            throw new RuntimeException("鏂囨。鏍煎紡涓嶆纭�!");
+        }
+        if (this.wb.getNumberOfSheets()<sheetIndex){
+            throw new RuntimeException("鏂囨。涓病鏈夊伐浣滆〃!");
+        }
+        this.sheet = this.wb.getSheetAt(sheetIndex);
+        this.headerNum = headerNum;
+        this.changeType = cellType;
+        log.debug("Initialize success.");
+    }
+
+
 
     /**
      * 鑾峰彇琛屽璞�
@@ -174,7 +211,8 @@
             Cell cell = row.getCell(column);
             if (cell != null){
                 if (cell.getCellType() == CellType.NUMERIC){
-                    val = cell.getNumericCellValue();
+                    cell.setCellType(CellType.STRING); // 纭繚鍗曞厓鏍肩被鍨嬩负瀛楃涓�
+                    val = cell.getStringCellValue();
                 }else if (cell.getCellType() == CellType.STRING){
                     val = cell.getStringCellValue();
                 }else if (cell.getCellType() == CellType.FORMULA){
@@ -295,7 +333,8 @@
                             }else{
                                 val = String.valueOf(val.toString()).trim();
                             }
-                        }else if (valType == Integer.class){
+                        }
+                        else if (valType == Integer.class){
                             val = Double.valueOf(val.toString()).intValue();
                         }else if (valType == Long.class){
                             val = Double.valueOf(val.toString()).longValue();

--
Gitblit v1.9.3