瀏覽代碼

优化Excel自定义格式样式重复创建问题

RuoYi 3 月之前
父節點
當前提交
0d85aa50a7
共有 1 個文件被更改,包括 12 次插入0 次删除
  1. 12 0
      ruoyi-common/src/main/java/com/ruoyi/common/utils/poi/ExcelUtil.java

+ 12 - 0
ruoyi-common/src/main/java/com/ruoyi/common/utils/poi/ExcelUtil.java

@@ -107,6 +107,11 @@ public class ExcelUtil<T>
     public Map<String, String> sysDictMap = new HashMap<String, String>();
 
     /**
+     * 单元格样式缓存
+     */
+    private Map<String, CellStyle> cellStyleCache = new HashMap<String, CellStyle>();
+
+    /**
      * Excel sheet最大行数,默认65536
      */
     public static final int sheetSize = 65536;
@@ -1201,9 +1206,16 @@ public class ExcelUtil<T>
      */
     private CellStyle createCellStyle(CellStyle cellStyle, String format)
     {
+        String key = cellStyle.getIndex() + "|" + format;
+        CellStyle cached = cellStyleCache.get(key);
+        if (cached != null)
+        {
+            return cached;
+        }
         CellStyle style = wb.createCellStyle();
         style.cloneStyleFrom(cellStyle);
         style.setDataFormat(wb.getCreationHelper().createDataFormat().getFormat(format));
+        cellStyleCache.put(key, style);
         return style;
     }