|
|
|
@ -14,6 +14,7 @@ import java.util.Date;
@@ -14,6 +14,7 @@ import java.util.Date;
|
|
|
|
|
import java.util.HashMap; |
|
|
|
|
import java.util.List; |
|
|
|
|
import java.util.Map; |
|
|
|
|
import java.util.Set; |
|
|
|
|
import java.util.stream.Collectors; |
|
|
|
|
import javax.servlet.http.HttpServletResponse; |
|
|
|
|
import org.apache.poi.hssf.usermodel.HSSFDateUtil; |
|
|
|
@ -98,6 +99,16 @@ public class ExcelUtil<T>
@@ -98,6 +99,16 @@ public class ExcelUtil<T>
|
|
|
|
|
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; |
|
|
|
@ -337,6 +348,7 @@ public class ExcelUtil<T>
@@ -337,6 +348,7 @@ public class ExcelUtil<T>
|
|
|
|
|
if (Type.EXPORT.equals(type)) |
|
|
|
|
{ |
|
|
|
|
fillExcelData(index, row); |
|
|
|
|
addStatisticsRow(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
wb.write(outputStream); |
|
|
|
@ -439,6 +451,15 @@ public class ExcelUtil<T>
@@ -439,6 +451,15 @@ public class ExcelUtil<T>
|
|
|
|
|
headerFont.setColor(IndexedColors.WHITE.getIndex()); |
|
|
|
|
style.setFont(headerFont); |
|
|
|
|
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; |
|
|
|
|
} |
|
|
|
@ -546,6 +567,7 @@ public class ExcelUtil<T>
@@ -546,6 +567,7 @@ public class ExcelUtil<T>
|
|
|
|
|
// 设置列类型
|
|
|
|
|
setCellVo(value, attr, cell); |
|
|
|
|
} |
|
|
|
|
addStatisticsData(column, Convert.toStr(value), attr); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
catch (Exception e) |
|
|
|
@ -687,6 +709,53 @@ public class ExcelUtil<T>
@@ -687,6 +709,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(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 获取bean中的属性值 |
|
|
|
|
* |
|
|
|
|
* @param vo 实体对象 |
|
|
|
|