EasyExcel中处理表头行高和内容行高

在学习easyExcek 时,发现使用easyExcek 处理表头和内容的行高十分容易只需要在类模型配置上使用@HeadRowHeight 或者@ContentRowHeight 注解实现控制。

  • 创建一个类模型配置类
java 复制代码
// 设置表头行高度
@HeadRowHeight(40)
// 设置内容行高度
@ContentRowHeight(60)
@Data
public class User {

  private String name;

  private String age;

  private String address;
}
  • 测试主类
java 复制代码
 public static void main(String[] args) {
     List<User> userList = new ArrayList<>();

    User user = new User();
    user.setName("李四");
    user.setAge("12");
    user.setAddress("火星");
    userList.add(user);

    EasyExcel.write("F:\\excel\\a.xls", User.class)
        .automaticMergeHead(false)
        .sheet()
        .doWrite(userList);
  }
  • 效果

    总体感觉还是很easy的。

下面看看具体的源码:

  • 注解@HeadRowHeight
java 复制代码
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
public @interface HeadRowHeight {
    /**
     * 设置表头高,默认是-1,-1 表示自动设置高度
     */
    short value() default -1;
}
  • 注解@ContentRowHeight
java 复制代码
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
public @interface ContentRowHeight {

    /**
     * 设置内容行高,默认是-1,-1 表示自动设置高度
     */
    short value() default -1;
}
  • 核心拦截器
java 复制代码
public abstract class AbstractRowHeightStyleStrategy implements RowWriteHandler {
  // 在完成该行的所有操作后调用。在填充的情况下,可以多次调用。
  @Override
  public void afterRowDispose(RowWriteHandlerContext context) {
    if (context.getHead() == null) {
      return;
    }
    
    // 当前是否是表头,是则调用setHeadColumnHeight
    // 反之调用setContentColumnHeight
    if (context.getHead()) {
      setHeadColumnHeight(context.getRow(), context.getRelativeRowIndex());
    } else {
      setContentColumnHeight(context.getRow(), context.getRelativeRowIndex());
    }
  }

  /**
   * 设置表头行高抽象方法,需要子类进行实现
   *
   */
  protected abstract void setHeadColumnHeight(Row row, int relativeRowIndex);

  /**
   * 设置内容行高抽象方法,需要子类进行实现
   *
   */
  protected abstract void setContentColumnHeight(Row row, int relativeRowIndex);

}
  • 唯一实现类
java 复制代码
public class SimpleRowHeightStyleStrategy extends AbstractRowHeightStyleStrategy {
  private final Short headRowHeight;
  private final Short contentRowHeight;

  public SimpleRowHeightStyleStrategy(Short headRowHeight, Short contentRowHeight) {
    this.headRowHeight = headRowHeight;
    this.contentRowHeight = contentRowHeight;
  }

  @Override
  protected void setHeadColumnHeight(Row row, int relativeRowIndex) {
    if (headRowHeight != null) {
      row.setHeightInPoints(headRowHeight);
    }
  }

  @Override
  protected void setContentColumnHeight(Row row, int relativeRowIndex) {
    if (contentRowHeight != null) {
      row.setHeightInPoints(contentRowHeight);
    }
  }

}
相关推荐
rannn_1112 分钟前
【苍穹外卖|Day4】套餐页面开发(新增套餐、分页查询、删除套餐、修改套餐、起售停售)
java·spring boot·后端·学习
qq_12498707536 分钟前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
短剑重铸之日12 分钟前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
若鱼191935 分钟前
SpringBoot4.0新特性-Observability让生产环境更易于观测
java·spring
觉醒大王43 分钟前
强女思维:着急,是贪欲外显的相。
java·论文阅读·笔记·深度学习·学习·自然语言处理·学习方法
努力学编程呀(๑•ี_เ•ี๑)1 小时前
【在 IntelliJ IDEA 中切换项目 JDK 版本】
java·开发语言·intellij-idea
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
向上的车轮1 小时前
为什么.NET(C#)转 Java 开发时常常在“吐槽”Java:checked exception
java·c#·.net
Dragon Wu1 小时前
Spring Security Oauth2.1 授权码模式实现前后端分离的方案
java·spring boot·后端·spring cloud·springboot·springcloud
跳动的梦想家h1 小时前
环境配置 + AI 提效双管齐下
java·vue.js·spring