
在 easytable(vandeseer/easytable)中,`row.builder().build()` 方法会直接返回构建完成的 `row` 对象,因此可通过变量保存最后一行实例,实现对其样式、单元格或高度等属性的后续访问与修改。
easyTable 是一个轻量、声明式 Java PDF 表格生成库,其设计强调不可变性与链式构建(builder pattern)。值得注意的是:Table 本身不提供类似 getLastRow() 的方法,Row 实例也并非由 Table 持有引用——所有行对象均由用户显式创建并传入 Table.builder().addRow(...)。这意味着“最后创建的行”完全取决于你代码中的赋值时机,而非表格内部状态。
✅ 正确做法:在调用 addRow() 前,将 Row.builder().build() 的返回值赋给局部变量:
// 创建并持有最后一行的引用
Row lastRow = Row.builder()
.add(Cell.builder().text("Total").build())
.add(Cell.builder().text("¥1,299.00").align(HorizontalAlignment.RIGHT).build())
.height(24f)
.build();
// 构建表格时加入该行
Table table = Table.builder()
.addRow(Row.builder().add(Cell.builder().text("Item").build()).build()) // 其他行...
.addRow(lastRow) // 显式添加
.build();此时,lastRow 即可用于:
- 动态修改样式(如设置背景色、字体加粗);
- 调整行高(lastRow.height = 30f);
- 访问其单元格列表(lastRow.getCells())进行内容校验或日志输出。
⚠️ 注意事项:
- Row 对象是不可变构建结果,但其字段(如 height、settings)为 public 且可写——这是库提供的扩展点,但需在 Table 渲染前完成修改;
- 若多处创建行,请确保变量作用域覆盖使用位置;避免在循环中反复覆盖同一变量而丢失前序行引用;
- 不要试图通过 table.getRows() 反向获取(easyTable 的 Table 类未暴露行列表,该设计有意为之,以保障构建过程的确定性)。
总结:easyTable 的“获取最后一行”本质是标准 Java 引用管理问题——利用 builder 方法的返回值,主动持有所需对象。这不仅符合函数式构建习惯,也避免了对内部状态的依赖,提升了代码可读性与可维护性。










