| | |
| | | |
| | | import java.util.*; |
| | | |
| | | /** |
| | | * Excel帮助类 |
| | | * @author WWW |
| | | */ |
| | | @SuppressWarnings("ALL") |
| | | public class ExcelHelper { |
| | | /** |
| | | * 读取Excel |
| | | * |
| | | * @param pathName 文件路径 |
| | | * @param <T> 泛型类 |
| | | * @return 泛型类集合 |
| | | */ |
| | | public static <T> List<T> readExcel(Class<?> clazz, String pathName) { |
| | | ExcelHead head = getExcelHead(clazz); |
| | | int headRowNumber = head == null ? 1 : head.headRows(); |
| | |
| | | return list; |
| | | } |
| | | |
| | | /** |
| | | * 获取Excel头注解类 |
| | | * |
| | | * @param clazz Class |
| | | * @param <T> 泛型类 |
| | | * @return 头行数 |
| | | */ |
| | | public static <T> ExcelHead getExcelHead(Class<?> clazz) { |
| | | ExcelHead head = clazz.getAnnotation(ExcelHead.class); |
| | | |
| | | return head; |
| | | } |
| | | |
| | | /** |
| | | * 写入Excel模板 |
| | | * |
| | | * @param source 源文件(模板) |
| | | * @param target 目录文件 |
| | | * @param map 数据源 |
| | | */ |
| | | public static <T> void writeToTemplate(String source, String target, Map<String, List<T>> map) { |
| | | // 根据模板写入数据,如果目标文件不存在,则自动创建文件 |
| | | ExcelWriter excelWriter = EasyExcel.write(target).withTemplate(source).build(); |
| | | |
| | | // 在工作簿0中写入数据,如果模板中不存在练习工作簿,则会在目标文件中自动创建 |
| | | WriteSheet writeSheet = EasyExcel.writerSheet(0).build(); |
| | | |
| | | // 垂直写入数据,如果要水平写入,将VERTICAL替换为HORIZONTAL |
| | | FillConfig fillConfig = FillConfig.builder().direction(WriteDirectionEnum.VERTICAL).build(); |
| | | |
| | | // 写入数据 |
| | | map.forEach((k, v) -> excelWriter.fill(new FillWrapper(k, v), fillConfig, writeSheet)); |
| | | |
| | | // 结束写入 |
| | | excelWriter.finish(); |
| | | } |
| | | } |