合并单元格,让表格更美好。

摘要

AsposeWords for java真是太强大了,不仅可以创建表格,还能轻松合并单元格。只需提供开始和结束单元格,调用mergeCells()函数即可,简单易懂,真是太方便了!

正文

强大的AsposeWords for java不仅支持创建表格,还支持合并单元格。今天就简明扼要记录下如何实现合并单元格。
大家可以完全套用本文提供的代码,只需要提供开始和结束的单元格即可实现合并,无需理解复杂的过程,真是简洁好用啊。
此代码来自官方网站,运行无误。
先看看合并的效果:

简单三步实现:
(1)设计一个模板,并确定要合并的开始和结束单元格
(2)调用合并单元格mergeCells()函数
(3)输出合并后word文档。

代码如下:

public static void main(String[] args) {
// TODO code application logic here
try{
Document doc = new Document("template.docx");
Table table = (Table) doc.getChild(NodeType.TABLE, 1, true); //第2个表格

// We want to merge the range of cells found in between these two cells.
Cell cellStartRange = table.getRows().get(1).getCells().get(0); //第2行第1列
Cell cellEndRange = table.getRows().get(2).getCells().get(0); //第3行第1列
// Merge all the cells between the two specified cells into one.
mergeCells(cellStartRange, cellEndRange);

cellStartRange = table.getRows().get(3).getCells().get(0); //第4行第1列
cellEndRange = table.getRows().get(5).getCells().get(0); //第6行第1列
// Merge all the cells between the two specified cells into one.
mergeCells(cellStartRange, cellEndRange);

doc.save(“out.docx”);
System.out.println(“Done”);
}
catch(Exception e) {
System.out.println(“error:”+e.getMessage() );
}

}

/**
* Merges the range of cells found between the two specified cells both
* horizontally and vertically. Can span over multiple rows.
* @param startCell
* @param endCell
*/
public static void mergeCells(Cell startCell, Cell endCell) {
Table parentTable = startCell.getParentRow().getParentTable();

// Find the row and cell indices for the start and end cell.
Point startCellPos = new Point(startCell.getParentRow().indexOf(startCell), parentTable.indexOf(startCell.getParentRow()));
Point endCellPos = new Point(endCell.getParentRow().indexOf(endCell), parentTable.indexOf(endCell.getParentRow()));
// Create the range of cells to be merged based off these indices. Inverse each index if the end cell if before the start cell.
Rectangle mergeRange = new Rectangle(Math.min(startCellPos.x, endCellPos.x), Math.min(startCellPos.y, endCellPos.y), Math.abs(endCellPos.x – startCellPos.x) + 1,
Math.abs(endCellPos.y – startCellPos.y) + 1);

for (Row row : parentTable.getRows()) {
for (Cell cell : row.getCells()) {
Point currentPos = new Point(row.indexOf(cell), parentTable.indexOf(row));

// Check if the current cell is inside our merge range then merge it.
if (mergeRange.contains(currentPos)) {
if (currentPos.x == mergeRange.x)
cell.getCellFormat().setHorizontalMerge(CellMerge.FIRST);
else
cell.getCellFormat().setHorizontalMerge(CellMerge.PREVIOUS);

if (currentPos.y == mergeRange.y)
cell.getCellFormat().setVerticalMerge(CellMerge.FIRST);
else
cell.getCellFormat().setVerticalMerge(CellMerge.PREVIOUS);
}
}
}
}

真的简单明了,没啥好说的。

关注不迷路

扫码下方二维码,关注宇凡盒子公众号,免费获取最新技术内幕!

温馨提示:如果您访问和下载本站资源,表示您已同意只将下载文件用于研究、学习而非其他用途。
文章版权声明 1、本网站名称:宇凡盒子
2、本站文章未经许可,禁止转载!
3、如果文章内容介绍中无特别注明,本网站压缩包解压需要密码统一是:yufanbox.com
4、本站仅供资源信息交流学习,不保证资源的可用及完整性,不提供安装使用及技术服务。点此了解
5、如果您发现本站分享的资源侵犯了您的权益,请及时通知我们,我们会在接到通知后及时处理!提交入口
0

评论0

请先

站点公告

🚀 【宇凡盒子】全网资源库转储中心

👉 注册即送VIP权限👈

👻 全站资源免费下载✅,欢迎注册!

记得 【收藏】+【关注】 谢谢!~~~

立即注册
没有账号?注册  忘记密码?

社交账号快速登录