注解+Excel 导出

1、标题注解


@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
/**
 * 中文注解,用于Excel文件导出,实体对象字段注解
 */
public @interface FieldChinese {
    String name() default "";
}

2、 Excel导出

/**
     * excel导出,标题映射根据实体类@ApiModelProperty注解 value值设置
     *
     * @param response
     * @param clazz     导出实体映射
     * @param list      数据
     * @param excelName excel名字
     * @throws Exception
     */
    public static void export(HttpServletResponse response, Class clazz, List<?> list,
                              String excelName, String title) throws Exception {
        if (!list.isEmpty()) {
            if (!list.get(0).getClass().equals(clazz)) {
                logger.error("数据类型与传入的集合数据类型不一致!数据类型:{}; 集合数据类型:{}", clazz, list.get(0).getClass());
                throw new LogicException("数据类型与传入的数据类型不一致!");
            } else {
                ExcelWriter writer = ExcelUtil.getWriter();
                // 获取当前类字段
                Field[] fields = clazz.getDeclaredFields();
                // 字段名称集合
                List<String> fieldNames = new ArrayList<>();
                // 字段中文名称集合(获取实体中@ApiModelProperty注解value的值)
                List<String> cnNames = new ArrayList<>();
                for (Field field : fields) {
                    if (!field.isAccessible()) {
                        // 关闭反射访问安全检查,为了提高速度
                        field.setAccessible(true);
                    }
                    String fieldName = field.getName();
                    // 排除ID和序号
                    if (!"sid".equals(fieldName) && !"serialVersionUID".equals(fieldName) && !"ordernum"
                            .equals(fieldName)) {
                        fieldNames.add(fieldName);
                    }
                    // 判断是否有@ApiModelProperty注解
                    boolean annotationPresent = field.isAnnotationPresent(FieldChinese.class);
                    if (annotationPresent && !"sid".equals(fieldName)) {
                        FieldChinese annotation = field.getAnnotation(FieldChinese.class);
                        String name = annotation.name();
                        cnNames.add(name);
                    }
                }
                String[] fs = fieldNames.toArray(new String[0]);
                String[] ns = cnNames.toArray(new String[0]);
                for (int i = 0; i < ns.length; i++) {
                    // 设置表头及字段名
                    writer.addHeaderAlias(fs[i], ns[i]);
                }
                // 自动换行
                Workbook workbook = writer.getWorkbook();
                StyleSet styleSet = new StyleSet(workbook);
                styleSet.setWrapText();
                writer.setStyleSet(styleSet);
                // 定义单元格背景色
                StyleSet style = writer.getStyleSet();
                CellStyle headCellStyle = style.getHeadCellStyle();
                //设置内容字体
                Font font = writer.createFont();
                //加粗
                font.setBold(true);
                //设置标题字体大小
                font.setFontHeightInPoints((short) 14);
                headCellStyle.setFont(font);
                writer.setStyleSet(style);

                // 写入大标题
                writer.merge(fs.length - 1, title, false);
                writer.write(list, true);
                ServletOutputStream out = response.getOutputStream();
                try {
                    for (int i = 0; i < fieldNames.size(); i++) {
                        writer.setColumnWidth(i, 23);
                    }
                    response.setContentType("application/x-msdownload;charset=utf-8");
                    String ecodeFileName = URLEncoder.encode(excelName, "UTF-8") + LocalDate.now();
                    response.setHeader("Content-Disposition",
                            "attachment;filename=" + ecodeFileName + ";" + "filename*=utf-8''" + ecodeFileName
                                    + ".xls");
                    writer.flush(out, true);
                    writer.close();
                    IoUtil.close(out);
                } catch (IOException e) {
                    logger.error(e.getMessage());
                    e.printStackTrace();
                    throw new FeignException(500, "程序内部发生错误,数据导出异常");
                }
            }
        } else {
            logger.error("数据集合为空");
            throw new FeignException(500, "暂无数据,无法导出;");
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自己封装的excel导出/导入,可以根据注解导出excel.本项目一共有13个类,里面还包含了一个反射工具,一个编码工具,10分值了。下面是测试代码 public class Test { public static void main(String[] arg) throws FileNotFoundException, IOException{ testBean(); testMap(); } public static void testBean() throws FileNotFoundException, IOException{ List l = new ArrayList(); for(int i=0;i<100;i++){ l.add(new MyBean()); } //很轻松,只需要二句话就能导出excel BeanExport be = ExportExcel.BeanExport(MyBean.class); be.createBeanSheet("1月份", "1月份人员信息").addData(l); be.createBeanSheet("2月份","2月份人员信息").addData(l); be.writeFile("E:/test/bean人员信息8.xlsx"); } //如果不想用注解,还能根据MAP导出. public static void testMap () throws FileNotFoundException, IOException{ List l = new ArrayList(); l.add(new MapHeader("姓名","name",5000)); l.add(new MapHeader("年龄","age",4000)); l.add(new MapHeader("生日","birthdate",3000)); l.add(new MapHeader("地址","address",5000)); l.add(new MapHeader("双精度","d",4000)); l.add(new MapHeader("float","f",6000)); List<Map> lm = new ArrayList<Map>(); for(int i=0;i<100;i++){ Map map = new HashMap(); map.put("name","闪电球"); map.put("age",100); map.put("birthdate",new Date()); map.put("address","北京市广东省AAA号123楼!"); map.put("d",22.222d); map.put("f",295.22f); lm.add(map); } MapExport me = ExportExcel.mapExport(l); me.createMapSheel("1月份","广东省人员信息").addData(lm); me.createMapSheel("2月份", "北京市人员信息").addData(lm); me.writeFile("E:/test/map人员信息9.xlsx"); } }
Java注解是一种元数据,它可以为类、方法、字段等元素添加额外的信息。在Java中,可以使用自定义注解和反射来实现导入导出Excel文档。 首先,定义一个自定义注解,用于标记需要导出的实体类的字段: ```java @Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) public @interface ExcelField { /** * 列名 */ public String name(); /** * 顺序 */ public int order(); } ``` 然后,在实体类的字段上添加该注解: ```java public class User { @ExcelField(name = "姓名", order = 1) private String name; @ExcelField(name = "年龄", order = 2) private int age; // 省略其他字段和方法 } ``` 接着,定义一个工具类,用于读取和写入Excel文档: ```java public class ExcelUtil { /** * 从Excel中读取数据 */ public static <T> List<T> readFromExcel(InputStream is, Class<T> clazz) { List<T> list = new ArrayList<>(); try { Workbook workbook = WorkbookFactory.create(is); Sheet sheet = workbook.getSheetAt(0); Map<Integer, String> headers = getHeaders(sheet.getRow(0)); for (int i = 1; i <= sheet.getLastRowNum(); i++) { Row row = sheet.getRow(i); T obj = clazz.newInstance(); for (int j = 0; j < row.getLastCellNum(); j++) { Cell cell = row.getCell(j); String value = getValue(cell); String fieldName = headers.get(j); Field field = clazz.getDeclaredField(fieldName); field.setAccessible(true); setValue(obj, field, value); } list.add(obj); } } catch (Exception e) { e.printStackTrace(); } return list; } /** * 写入数据到Excel中 */ public static <T> void writeToExcel(List<T> list, OutputStream os) { try { Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet(); Row header = sheet.createRow(0); Map<String, Integer> fields = getFields(list.get(0).getClass()); List<String> fieldNames = new ArrayList<>(fields.keySet()); Collections.sort(fieldNames); for (int i = 0; i < fieldNames.size(); i++) { String fieldName = fieldNames.get(i); Cell cell = header.createCell(i); cell.setCellValue(fields.get(fieldName)); } for (int i = 0; i < list.size(); i++) { Row row = sheet.createRow(i + 1); T obj = list.get(i); for (int j = 0; j < fieldNames.size(); j++) { String fieldName = fieldNames.get(j); Field field = obj.getClass().getDeclaredField(fieldName); field.setAccessible(true); Object value = field.get(obj); Cell cell = row.createCell(j); cell.setCellValue(value.toString()); } } workbook.write(os); } catch (Exception e) { e.printStackTrace(); } } /** * 获取Excel中的列名 */ private static Map<Integer, String> getHeaders(Row row) { Map<Integer, String> headers = new HashMap<>(); for (int i = 0; i < row.getLastCellNum(); i++) { Cell cell = row.getCell(i); String value = getValue(cell); headers.put(i, value); } return headers; } /** * 获取实体类中的字段名和顺序 */ private static <T> Map<String, Integer> getFields(Class<T> clazz) { Map<String, Integer> fields = new HashMap<>(); Field[] declaredFields = clazz.getDeclaredFields(); for (Field field : declaredFields) { if (field.isAnnotationPresent(ExcelField.class)) { ExcelField excelField = field.getAnnotation(ExcelField.class); fields.put(field.getName(), excelField.order()); } } return fields; } /** * 设置实体类中的字段值 */ private static <T> void setValue(T obj, Field field, String value) throws Exception { String typeName = field.getType().getName(); if ("int".equals(typeName)) { field.set(obj, Integer.parseInt(value)); } else if ("java.lang.String".equals(typeName)) { field.set(obj, value); } // 省略其他类型的判断 } /** * 获取单元格中的值 */ private static String getValue(Cell cell) { String value = ""; if (cell != null) { switch (cell.getCellType()) { case STRING: value = cell.getStringCellValue(); break; case NUMERIC: if (DateUtil.isCellDateFormatted(cell)) { Date date = cell.getDateCellValue(); value = new SimpleDateFormat("yyyy-MM-dd").format(date); } else { value = String.valueOf(cell.getNumericCellValue()); } break; case BOOLEAN: value = String.valueOf(cell.getBooleanCellValue()); break; case FORMULA: value = String.valueOf(cell.getCellFormula()); break; default: value = ""; } } return value; } } ``` 最后,可以使用该工具类来读取和写入Excel文档: ```java public class Main { public static void main(String[] args) { // 从Excel中读取数据 try (InputStream is = new FileInputStream("users.xlsx")) { List<User> list = ExcelUtil.readFromExcel(is, User.class); for (User user : list) { System.out.println(user.getName() + ", " + user.getAge()); } } catch (Exception e) { e.printStackTrace(); } // 写入数据到Excel中 List<User> list = new ArrayList<>(); list.add(new User("张三", 20)); list.add(new User("李四", 30)); list.add(new User("王五", 40)); try (OutputStream os = new FileOutputStream("users.xlsx")) { ExcelUtil.writeToExcel(list, os); } catch (Exception e) { e.printStackTrace(); } } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值