|  | @@ -16,6 +16,7 @@ import java.util.Date;
 | 
											
												
													
														|  |  import java.util.HashMap;
 |  |  import java.util.HashMap;
 | 
											
												
													
														|  |  import java.util.List;
 |  |  import java.util.List;
 | 
											
												
													
														|  |  import java.util.Map;
 |  |  import java.util.Map;
 | 
											
												
													
														|  | 
 |  | +import java.util.Set;
 | 
											
												
													
														|  |  import java.util.UUID;
 |  |  import java.util.UUID;
 | 
											
												
													
														|  |  import java.util.stream.Collectors;
 |  |  import java.util.stream.Collectors;
 | 
											
												
													
														|  |  import org.apache.poi.hssf.usermodel.HSSFDateUtil;
 |  |  import org.apache.poi.hssf.usermodel.HSSFDateUtil;
 | 
											
										
											
												
													
														|  | @@ -104,6 +105,16 @@ public class ExcelUtil<T>
 | 
											
												
													
														|  |      private List<Object[]> fields;
 |  |      private List<Object[]> fields;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      /**
 |  |      /**
 | 
											
												
													
														|  | 
 |  | +     * 统计列表
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    private Map<Integer, Double> statistics = new HashMap<Integer, Double>();
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * 数字格式
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    private static final DecimalFormat DOUBLE_FORMAT = new DecimalFormat("######0.00");
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  |       * 实体对象
 |  |       * 实体对象
 | 
											
												
													
														|  |       */
 |  |       */
 | 
											
												
													
														|  |      public Class<T> clazz;
 |  |      public Class<T> clazz;
 | 
											
										
											
												
													
														|  | @@ -342,6 +353,7 @@ public class ExcelUtil<T>
 | 
											
												
													
														|  |                  if (Type.EXPORT.equals(type))
 |  |                  if (Type.EXPORT.equals(type))
 | 
											
												
													
														|  |                  {
 |  |                  {
 | 
											
												
													
														|  |                      fillExcelData(index, row);
 |  |                      fillExcelData(index, row);
 | 
											
												
													
														|  | 
 |  | +                    addStatisticsRow();
 | 
											
												
													
														|  |                  }
 |  |                  }
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |              String filename = encodingFilename(sheetName);
 |  |              String filename = encodingFilename(sheetName);
 | 
											
										
											
												
													
														|  | @@ -448,6 +460,15 @@ public class ExcelUtil<T>
 | 
											
												
													
														|  |          headerFont.setColor(IndexedColors.WHITE.getIndex());
 |  |          headerFont.setColor(IndexedColors.WHITE.getIndex());
 | 
											
												
													
														|  |          style.setFont(headerFont);
 |  |          style.setFont(headerFont);
 | 
											
												
													
														|  |          styles.put("header", style);
 |  |          styles.put("header", style);
 | 
											
												
													
														|  | 
 |  | +        
 | 
											
												
													
														|  | 
 |  | +        style = wb.createCellStyle();
 | 
											
												
													
														|  | 
 |  | +        style.setAlignment(HorizontalAlignment.CENTER);
 | 
											
												
													
														|  | 
 |  | +        style.setVerticalAlignment(VerticalAlignment.CENTER);
 | 
											
												
													
														|  | 
 |  | +        Font totalFont = wb.createFont();
 | 
											
												
													
														|  | 
 |  | +        totalFont.setFontName("Arial");
 | 
											
												
													
														|  | 
 |  | +        totalFont.setFontHeightInPoints((short) 10);
 | 
											
												
													
														|  | 
 |  | +        style.setFont(totalFont);
 | 
											
												
													
														|  | 
 |  | +        styles.put("total", style);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          return styles;
 |  |          return styles;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
										
											
												
													
														|  | @@ -560,6 +581,7 @@ public class ExcelUtil<T>
 | 
											
												
													
														|  |                      // 设置列类型
 |  |                      // 设置列类型
 | 
											
												
													
														|  |                      setCellVo(value, attr, cell);
 |  |                      setCellVo(value, attr, cell);
 | 
											
												
													
														|  |                  }
 |  |                  }
 | 
											
												
													
														|  | 
 |  | +                addStatisticsData(column, Convert.toStr(value), attr);
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |          catch (Exception e)
 |  |          catch (Exception e)
 | 
											
										
											
												
													
														|  | @@ -727,6 +749,53 @@ public class ExcelUtil<T>
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      /**
 |  |      /**
 | 
											
												
													
														|  | 
 |  | +     * 合计统计信息
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    private void addStatisticsData(Integer index, String text, Excel entity)
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        if (entity != null && entity.isStatistics())
 | 
											
												
													
														|  | 
 |  | +        {
 | 
											
												
													
														|  | 
 |  | +            Double temp = 0D;
 | 
											
												
													
														|  | 
 |  | +            if (!statistics.containsKey(index))
 | 
											
												
													
														|  | 
 |  | +            {
 | 
											
												
													
														|  | 
 |  | +                statistics.put(index, temp);
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            try
 | 
											
												
													
														|  | 
 |  | +            {
 | 
											
												
													
														|  | 
 |  | +                temp = Double.valueOf(text);
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            catch (NumberFormatException e)
 | 
											
												
													
														|  | 
 |  | +            {
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            statistics.put(index, statistics.get(index) + temp);
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * 创建统计行
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    public void addStatisticsRow()
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        if (statistics.size() > 0)
 | 
											
												
													
														|  | 
 |  | +        {
 | 
											
												
													
														|  | 
 |  | +            Cell cell = null;
 | 
											
												
													
														|  | 
 |  | +            Row row = sheet.createRow(sheet.getLastRowNum() + 1);
 | 
											
												
													
														|  | 
 |  | +            Set<Integer> keys = statistics.keySet();
 | 
											
												
													
														|  | 
 |  | +            cell = row.createCell(0);
 | 
											
												
													
														|  | 
 |  | +            cell.setCellStyle(styles.get("total"));
 | 
											
												
													
														|  | 
 |  | +            cell.setCellValue("合计");
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            for (Integer key : keys)
 | 
											
												
													
														|  | 
 |  | +            {
 | 
											
												
													
														|  | 
 |  | +                cell = row.createCell(key);
 | 
											
												
													
														|  | 
 |  | +                cell.setCellStyle(styles.get("total"));
 | 
											
												
													
														|  | 
 |  | +                cell.setCellValue(DOUBLE_FORMAT.format(statistics.get(key)));
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            statistics.clear();
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  |       * 编码文件名
 |  |       * 编码文件名
 | 
											
												
													
														|  |       */
 |  |       */
 | 
											
												
													
														|  |      public String encodingFilename(String filename)
 |  |      public String encodingFilename(String filename)
 |