easypoi实现自定义样式

实现IExcelExportStyler接口

public class ExcelStyleUtil implements IExcelExportStyler {
    private static final short STRING_FORMAT = (short) BuiltinFormats.getBuiltinFormat("TEXT");
    private static final short FONT_SIZE_TEN = 11;
    private static final short FONT_SIZE_ELEVEN = 13;
    private static final short FONT_SIZE_TWELVE = 20;
    /**
     * 大标题样式
     */
    private CellStyle headerStyle;
    /**
     * 每列标题样式
     */
    private CellStyle titleStyle;
    /**
     * 数据行样式
     */
    private CellStyle styles;

    public ExcelStyleUtil(Workbook workbook) {
        this.init(workbook);
    }

    /**
     * 初始化样式
     *
     * @param workbook
     */
    private void init(Workbook workbook) {
        this.headerStyle = initHeaderStyle(workbook);
        this.titleStyle = initTitleStyle(workbook);
        this.styles = initStyles(workbook);
    }

    /**
     * 大标题样式
     *
     * @param color
     * @return
     */
    @Override
    public CellStyle getHeaderStyle(short color) {
        return headerStyle;
    }

    /**
     * 每列标题样式
     *
     * @param color
     * @return
     */
    @Override
    public CellStyle getTitleStyle(short color) {
        return titleStyle;
    }

    /**
     * 数据行样式
     *
     * @param parity 可以用来表示奇偶行
     * @param entity 数据内容
     * @return 样式
     */
    @SuppressWarnings("deprecation")
    @Override
    public CellStyle getStyles(boolean parity, ExcelExportEntity entity) {
        return styles;
    }

    /**
     * 获取样式方法
     *
     * @param dataRow 数据行
     * @param obj     对象
     * @param data    数据
     */
    @Override
    public CellStyle getStyles(Cell cell, int dataRow, ExcelExportEntity entity, Object obj, Object data) {
        return getStyles(true, entity);
    }

    /**
     * 模板使用的样式设置
     */
    @Override
    public CellStyle getTemplateStyles(boolean isSingle, ExcelForEachParams excelForEachParams) {
        return null;
    }

    /**
     * 初始化--大标题样式
     *
     * @param workbook
     * @return
     */
    private CellStyle initHeaderStyle(Workbook workbook) {
        CellStyle style = getBaseCellStyle(workbook);

        style.setFont(getFont(workbook, FONT_SIZE_TWELVE, true,"黑体"));
        return style;
    }

    /**
     * 初始化--每列标题样式
     *
     * @param workbook
     * @return
     */
    private CellStyle initTitleStyle(Workbook workbook) {
        CellStyle style = getBaseCellStyle(workbook);

        style.setFont(getFont(workbook, FONT_SIZE_ELEVEN, false,"黑体"));
        //背景色
        style.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        return style;
    }

    /**
     * 初始化--数据行样式
     *
     * @param workbook
     * @return
     */
    private CellStyle initStyles(Workbook workbook) {
        CellStyle style = getBaseCellStyle(workbook);
        style.setFont(getFont(workbook, FONT_SIZE_TEN, false,"宋体"));
        style.setDataFormat(STRING_FORMAT);
        return style;
    }

    /**
     * 基础样式
     *
     * @return
     */
    private CellStyle getBaseCellStyle(Workbook workbook) {
        CellStyle style = workbook.createCellStyle();
        //下边框
        style.setBorderBottom(BorderStyle.THIN);
        //左边框
        style.setBorderLeft(BorderStyle.THIN);
        //上边框
        style.setBorderTop(BorderStyle.THIN);
        //右边框
        style.setBorderRight(BorderStyle.THIN);
        //水平居中
        style.setAlignment(HorizontalAlignment.CENTER);
        //上下居中
        style.setVerticalAlignment(VerticalAlignment.CENTER);
        //设置自动换行
        style.setWrapText(true);
        return style;
    }

    /**
     * 字体样式
     *
     * @param size   字体大小
     * @param isBold 是否加粗
     * @return
     */
    private Font getFont(Workbook workbook, short size, boolean isBold,String fontName) {
        Font font = workbook.createFont();
        //字体样式
        font.setFontName(fontName);
        //是否加粗
        font.setBold(isBold);
        //字体大小
        font.setFontHeightInPoints(size);
        return font;
    }
}

自定义数据行高度

  Workbook book = ExcelExportUtil.exportExcel(exportParams, FtEnterprise.class, data);
            if (book != null) {
                //设置标题,内容 行高
                Sheet sheet = book.getSheetAt(0);
                for (int i = 0; i <= sheet.getLastRowNum(); i++) {
                    Row row = sheet.getRow(i);
                    if (i == 0) {
                        //设置第一行的行高(表格标题)
                        row.setHeightInPoints(50);
                    } else if (i == 3) {
                        //设置第二行的行高(表格表头)
                        row.setHeightInPoints(175);
                    } else {
                        //设置其他行的行高根据内容自适应
                        row.setHeightInPoints(30);
                    }
                }
          
            }

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
是的,easypoi可以实现动态导出并且可以改变样式。下面是一个简单的例子: ```java //创建一个Excel导出工具类 ExcelExportUtil excelExportUtil = new ExcelExportUtil(); //设置导出样式 ExcelExportStylerExcelExportStyler = new CustomExcelExportStylerImpl(); excelExportUtil.setStyler(customExcelExportStyler); //创建一个导出数据列表 List<User> userList = userService.getUserList(); //创建一个导出列信息列表 List<ExcelExportEntity> columnList = new ArrayList<ExcelExportEntity>(); columnList.add(new ExcelExportEntity("ID", "id")); columnList.add(new ExcelExportEntity("姓名", "name")); columnList.add(new ExcelExportEntity("年龄", "age")); //导出Excel文件 Workbook workbook = excelExportUtil.exportExcel(new ExportParams("用户信息", "用户信息"), columnList, userList); ``` 在上面的代码中,我们首先创建了一个Excel导出工具类ExcelExportUtil,并设置了一个自定义的导出样式CustomExcelExportStylerImpl。然后创建了一个导出数据列表userList和一个导出列信息列表columnList。最后调用ExcelExportUtil的exportExcel方法,将导出数据列表、导出列信息列表、以及导出参数ExportParams传入,生成Workbook对象,即可得到一个带有自定义样式的Excel文件。 需要注意的是,在上面的代码中,CustomExcelExportStylerImpl是一个自定义样式实现类,需要继承easypoi的ExcelExportStylerAbstract类,并重写其中的方法,以实现自定义样式

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值