|
|
@ -14,6 +14,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.stream.Collectors;
|
|
|
|
import java.util.stream.Collectors;
|
|
|
|
import javax.servlet.http.HttpServletResponse;
|
|
|
|
import javax.servlet.http.HttpServletResponse;
|
|
|
|
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
|
|
|
|
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
|
|
|
@ -97,6 +98,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");
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* 实体对象
|
|
|
|
* 实体对象
|
|
|
|
*/
|
|
|
|
*/
|
|
|
@ -337,6 +348,7 @@ public class ExcelUtil<T>
|
|
|
|
if (Type.EXPORT.equals(type))
|
|
|
|
if (Type.EXPORT.equals(type))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fillExcelData(index, row);
|
|
|
|
fillExcelData(index, row);
|
|
|
|
|
|
|
|
addStatisticsRow();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
wb.write(outputStream);
|
|
|
|
wb.write(outputStream);
|
|
|
@ -440,6 +452,15 @@ public class ExcelUtil<T>
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -546,6 +567,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)
|
|
|
@ -686,6 +708,53 @@ public class ExcelUtil<T>
|
|
|
|
return StringUtils.stripEnd(propertyString.toString(), separator);
|
|
|
|
return StringUtils.stripEnd(propertyString.toString(), separator);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* 合计统计信息
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
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中的属性值
|
|
|
|
* 获取bean中的属性值
|
|
|
|
*
|
|
|
|
*
|
|
|
|