From 2191824072549f0da35d73686a075e59b0196321 Mon Sep 17 00:00:00 2001
From: ZY <zc857179121@qq.com>
Date: 星期三, 25 九月 2024 15:02:25 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/wms-dev' into wms-dev
---
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/utils/ExcelUtil.java |  102 +++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 94 insertions(+), 8 deletions(-)
diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/utils/ExcelUtil.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/utils/ExcelUtil.java
index 1fc6dce..b0dcfa6 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/utils/ExcelUtil.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/utils/ExcelUtil.java
@@ -2,21 +2,22 @@
 
 import com.zy.asrs.framework.common.Cools;
 import com.zy.asrs.wms.asrs.entity.MatField;
+import com.zy.asrs.wms.asrs.entity.template.OrderTemplate;
 import io.swagger.annotations.ApiModelProperty;
 import org.apache.poi.hssf.usermodel.HSSFWorkbook;
-import org.apache.poi.ss.usermodel.Row;
-import org.apache.poi.ss.usermodel.Sheet;
-import org.apache.poi.ss.usermodel.Workbook;
+import org.apache.poi.ss.usermodel.*;
+import org.springframework.web.multipart.MultipartFile;
 
 import javax.servlet.http.HttpServletResponse;
 import java.io.IOException;
 import java.lang.reflect.Field;
+import java.lang.reflect.Method;
 import java.lang.reflect.Modifier;
 import java.net.URLEncoder;
 import java.text.SimpleDateFormat;
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
 
 /**
  * Created by vincent on 2/17/2024
@@ -52,7 +53,7 @@
             }
             String memo = "鏈煡";
             if (field.isAnnotationPresent(ApiModelProperty.class)) {
-                memo = field.getAnnotation(ApiModelProperty.class).value();
+                memo = field.getAnnotation(ApiModelProperty.class).value() + "[" + field.getName() + "]";
             }
             header.createCell(headerIdx).setCellValue(memo);
             headerIdx++;
@@ -61,7 +62,7 @@
         //鍔ㄦ�佸瓧娈�
         if(dynamicFields != null){
             for (MatField field : dynamicFields) {
-                header.createCell(headerIdx).setCellValue(field.getDescribe());
+                header.createCell(headerIdx).setCellValue(field.getDescribe() + "[" + field.getName() + "]");
                 headerIdx++;
             }
         }
@@ -125,6 +126,91 @@
         return workbook;
     }
 
+    public static <T> List<T> parseExcelFile(MultipartFile file, Class<T> clz) {
+        List<T> dataList = new ArrayList<>();
+        try (Workbook workbook = new HSSFWorkbook(file.getInputStream())) {
+            ArrayList<HashMap<String, Object>> list = new ArrayList<>();
+            ArrayList<String> fields = new ArrayList<>();
 
+            Sheet sheet = workbook.getSheetAt(0);
+            for (Row row : sheet) {
+                HashMap<String, Object> map = new HashMap<>();
+                if (!fields.isEmpty()) {
+                    for (String field : fields) {
+                        map.put(field, null);
+                    }
+                    list.add(map);
+                }
+
+                for (Cell cell : row) {
+                    if (cell.getRowIndex() == 0) {
+                        Pattern pattern = Pattern.compile("\\[(.*?)\\]");
+                        Matcher matcher = pattern.matcher(cell.getStringCellValue());
+                        while (matcher.find()) {
+                            fields.add(matcher.group(1));
+                        }
+                    }else {
+                        String value = "";
+                        if(cell.getCellType() == CellType.NUMERIC.getCode()) {
+                            // 鍏堝皢鏁板瓧杞崲涓哄瓧绗︿覆
+                            value = String.valueOf(cell.getNumericCellValue());
+                            // 澶勭悊瀛楃涓瞯alue
+                        } else if(cell.getCellType() == CellType.STRING.getCode()) {
+                            // 鐩存帴鑾峰彇瀛楃涓插��
+                            value = cell.getStringCellValue();
+                            // 澶勭悊瀛楃涓瞯alue
+                        }
+                        map.put(fields.get(cell.getColumnIndex()), value);
+                    }
+                }
+
+            }
+
+            for (HashMap<String, Object> map : list) {
+                T t = ExcelUtil.parseData(clz, map);
+                dataList.add(t);
+            }
+
+        } catch (IOException e) {
+            e.printStackTrace();
+        }
+        return dataList;
+    }
+
+    public static <T> T parseData(Class<T> clz, Map<String, Object> map) {
+        try {
+            T newInstance = clz.newInstance();
+            Field[] fields = Cools.getAllFields(clz);
+            for (Field field : fields) {
+                field.setAccessible(true);
+                if (!map.containsKey(field.getName())) {
+                    if (Modifier.isTransient(field.getModifiers()) && field.getName().equals("dynamicFields")) {
+                        Method method = clz.getMethod("syncFieldMap", Map.class);
+                        method.invoke(newInstance, map);
+                    }
+                    continue;
+                }
+                if (map.get(field.getName()) == null) {
+                    continue;
+                }
+                // 鍒ゆ柇瀛楁绫诲瀷骞惰祴鍊�
+                if (field.getType() == String.class) {
+                    field.set(newInstance, String.valueOf(map.get(field.getName())));
+                } else if (field.getType() == Integer.class) {
+                    field.set(newInstance, Integer.parseInt(map.get(field.getName()).toString()));
+                } else if (field.getType() == Float.class) {
+                    field.set(newInstance, Float.parseFloat(map.get(field.getName()).toString()));
+                } else if (field.getType() == Double.class) {
+                    field.set(newInstance, Double.parseDouble(map.get(field.getName()).toString()));
+                } else if (field.getType() == Boolean.class) {
+                    field.set(newInstance, Boolean.parseBoolean(map.get(field.getName()).toString()));
+                }
+            }
+            return newInstance;
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        return null;
+    }
 
 }
--
Gitblit v1.9.1