Excel导出的3种方式java

本文总结了使用Java导出Excel的三种方式:1) 使用Apache POI库创建ExcelUtil工具类;2) 引入Hutool库进行Excel导出;3) 利用ExcelKit库,通过注解方式定义列信息来导出Excel。
摘要由CSDN通过智能技术生成

导出Excel文件

最近又写了一个有关生成excel文件并导出的需求,下面总结下我所遇到的有关导出excel的方法。

poi方式

写个ExcelUtil工具类

@Slf4j
public class ExcelUtil {
    public static final String XLSX = ".xlsx";
    public static final String XLS = ".xls";
    /**
     * GBK编码.
     */
    public static final String CHARSET_GBK = "GBK";
    /**
     * Excel导出使用的字体名称.
     */
    private static final String FONT_NAME = "黑体";


    @Data
    @Builder
    public static class ExcelData {
        /**
         * sheet名称
         */
        private String sheetName;
        /**
         * 标题
         */
        private String titleName;
        /**
         * 列名
         */
        private String[] colsName;
        /**
         * 数据二维数组,第一维代表一行,第二维是每列
         */
        private List<List<Object>> dataList;
    }

    /**
     * 导出Excel(支持多sheet页).
     *
     * @param excelDataList excel数据
     * @param fileName      文件名
     * @param file          文件
     * @param uuid          请求流水
     * @throws IOException 异常
     */
    public static void export(final List<ExcelData> excelDataList, final String fileName, final File file, final String uuid) throws IOException {
        OutputStream out = new FileOutputStream(file);
        // 第一步,创建一个webbook
        Workbook wb;
        if (fileName.endsWith(XLS)) {
            wb = new HSSFWorkbook();
        } else {
            wb = new XSSFWorkbook();
        }

        // 循环写入sheet
        for (ExcelData excelData : excelDataList) {
            export(wb, excelData.getSheetName(), excelData.getTitleName(), excelData.getColsName(), excelData.getDataList());
        }



        // 最终 将文件写出到输出流
        try {
            wb.write(out);
            log.info("[请求流水:{},fileName:{}]导出Excel成功", uuid, fileName);
        } finally {
            IOUtils.closeQuietly(out);
        }

    }

    /**
     * 导出数据到Excel.
     *
     * @param sheetName sheet页名字
     * @param title     标题
     * @param colsName  列名数组
     * @param dataList  数据二位数组,第一维代表一行,第二维是每列
     */
    private static void export(Workbook wb, final String sheetName, final String title, final String[] colsName,
                               final List<List<Object>> dataList) {

        // 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet
        Sheet sheet = wb.createSheet(sheetName);

        // 第三步创建标题行
        final Row titleRow = sheet.createRow(0);
        // 设备标题的高度
        titleRow.setHeightInPoints(25);
        // 设计标题样式
        final CellStyle titleStyle = wb.createCellStyle();
        titleStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        titleStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
        titleStyle.setFillForegroundColor(HSSFColor.LIGHT_TURQUOISE.index);
        titleStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
        // 设置标题字
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值