Easyexcel(5-自定义列宽)

相关文章链接

  1. Easyexcel(1-注解使用)
  2. Easyexcel(2-文件读取)
  3. Easyexcel(3-文件导出)
  4. Easyexcel(4-模板文件)
  5. Easyexcel(5-自定义列宽)

注解

@ColumnWidth

@Data
public class WidthAndHeightData {
   
    
    @ExcelProperty("字符串标题")
    private String string;
    
    @ExcelProperty("日期标题")
    private Date date;

    @ColumnWidth(50)
    @ExcelProperty("数字标题")
    private Double doubleData;
}

注解使用时表头长度无法做到动态调整,只能固定设置,每次调整表头长度时只能重新修改代码

注意:@ColumnWidth最大值只能为255,超过255*256长度时会报错

查看XSSFSheet源码

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

类方法

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

AbstractHeadColumnWidthStyleStrategy

public abstract class AbstractHeadColumnWidthStyleStrategy extends AbstractColumnWidthStyleStrategy {
   

    @Override
    protected void setColumnWidth(WriteSheetHolder writeSheetHolder, List<WriteCellData<?>> cellDataList, Cell cell, Head head,
        Integer relativeRowIndex, Boolean isHead) {
   
        // 判断是否满足 当前行索引不为空 && (当前是表头 || 当前行索引是首行)
        // 如果不满足,则说明不是表头,不需要设置
        boolean needSetWidth = relativeRowIndex != null && (isHead || relativeRowIndex == 0);
        if (!needSetWidth) {
   
            return;
        }
        Integer width = columnWidth(head, cell.getColumnIndex());
        if (width != null) {
   
            width = width * 256;
            writeSheetHolder.getSheet().setColumnWidth(cell.getColumnIndex(), width);
        }
    }

    protected abstract Integer columnWidth(Head head, Integer columnIndex);
}

通过继承AbstractHeadColumnWidthStyleStrategy类,实现columnWidth方法获取其对应列的宽度

SimpleColumnWidthStyleStrategy

源码查看

public class SimpleColumnWidthStyleStrategy extends AbstractHeadColumnWidthStyleStrategy {
   
    private final Integer columnWidth;

    public SimpleColumnWidthStyleStrategy(Integer columnWidth) {
   
        this.columnWidth = columnWidth;
    }

    @Override
    protected Integer columnWidth(Head head, Integer columnIndex) {
   
        return columnWidth;
    }
}

基本使用

通过registerWriteHandler设置策略方法调整每列的固定宽度

@Data
public class User {
   

    @ExcelProperty(value = "用户Id")
    private Integer userId;

    @ExcelProperty(value = "姓名")
    private String name;

    @ExcelProperty(value = "手机")
    private String phone;

    @ExcelProperty(value = "邮箱")
    private String email;

    @ExcelProperty(value = "创建时间")
    private Date createTime;
}
@GetMapping("/download2")
public void download2(HttpServletResponse response) {
   
    try {
   
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf-8");
        // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
        String fileName = URLEncoder.encode("测试", "UTF-8").replaceAll("\\+", "%20");
        response.setHeader("Content-disposition", "a
### 关于EasyExcel自动调整的解决方案 在使用阿里巴巴开源的 EasyExcel 工具时,可以通过 `registerWriteHandler` 方法注册一个自定义处理器来实现 Excel 的自动调整功能。需要注意的是,在设置自定义处理器后,不能再通过注解方式(如 `@ColumnWidth`)单独设置,否则可能导致冲突并影响效果[^3]。 以下是具体的实现方案: #### 实现步骤解析 为了实现自动调整的功能,可以创建一个继承自 `AbstractCellWriteHandler` 的类,并重写其方法以完成对单元格度的计算和适配逻辑。具体代码如下所示: ```java import com.alibaba.excel.write.handler.CellWriteHandler; import org.apache.poi.ss.usermodel.*; public class CustomCellWriteHandler implements CellWriteHandler { @Override public void beforeCellCreate(WriteSheet writeSheet, WriteTable writeTable, Row row, Integer columnIndex, Class<?> clazz, Head head, Integer relativeRowIndex, Boolean isHead) { // 在此阶段无需操作任何内容 } @Override public void afterCellCreated(WriteSheet writeSheet, WriteTable writeTable, Cell cell, Head head, Integer relativeRowIndex, Boolean isHead) { Sheet sheet = cell.getSheet(); Workbook workbook = sheet.getWorkbook(); int columnIdx = cell.getColumnIndex(); ColumnHelper.adjustColumn(sheet, workbook, columnIdx); } } ``` 其中,`adjustColumn` 是用于动态调整的核心函数,其实现可参考以下代码片段: ```java public static final int DEFAULT_COLUMN_WIDTH = 25; public static void adjustColumn(Sheet sheet, Workbook wb, int colIndex) { if (colIndex >= MAX_AUTO_SIZE_COLUMNS || colIndex < MIN_AUTO_SIZE_COLUMNS) { return; // 超过最大范围则跳过处理 } sheet.autoSizeColumn(colIndex); // 自动调整当前至适合大小 int currentColWidth = sheet.getColumnWidth(colIndex); double charCountPerPx = getColumnCharCount(currentColWidth / ((double) DEFAULT_CHARACTER_WIDTH)); if (charCountPerPx < MIN_CHAR_COUNT_PER_PX) { // 如果字符数不足,则手动扩展到默认最小值 sheet.setColumnWidth(colIndex, Math.max(DEFAULT_MIN_COL_WIDTH * 256, currentColWidth)); } else if (currentColWidth > MAX_ALLOWED_COLUMN_WIDTH_IN_PIXELS * DEFAULT_CHARACTER_WIDTH) { sheet.setColumnWidth(colIndex, MAX_ALLOWED_COLUMN_WIDTH_IN_PIXELS * 256); // 设置上限防止过大 } } private static double getColumnCharCount(int pxValue) { return pxValue / DEFAULT_CHARACTER_WIDTH; } ``` 最后,在执行导出操作前需将该处理器绑定到对应的 Writer 对象上: ```java // 创建Writer实例 EasyExcel.write(outputFile).head(headList).registerWriteHandler(new CustomCellWriteHandler()).sheet("测试").doWrite(dataList); ``` 以上即为完整的 EasyExcel 动态调整配置教程及示例[^3]。 #### 注意事项 - 使用自定义处理器后不可再利用注解形式设定固定- 若涉及大量数据写入场景下建议优化性能避免频繁调用 autoSizeColumn() 方法以免造成效率低下问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值