-
Java 操作Word表格——创建嵌套表格、添加/复制表格行或列、设置表格是否禁止
本文将对如何在Java程序中操作Word表格作进一步介绍。操作要点包括
- 如何在Word中创建嵌套表格、
- 对已有表格添加行或者列
- 复制已有表格中的指定行或者列
- 对跨页的表格可设置是否禁止跨页断行
创建表格,包括添加数据、插入表格、合并单元格、设置表格样式、单元格居中、单元格背景色,单元格字体样式等设置
使用工具:Free Spire.Doc for Java (免费版)
Jar文件可通过官网下载jar https://www.e-iceblue.cn/Introduce/Free-Spire-Doc-JAVA.html文件包,下载后,解压文件,将lib文件夹下的Spire.Doc.jar导入Java程序;也可以在maven项目中通过maven http://repo.e-iceblue.com/nexus/content/groups/public/e-iceblue/仓库安装导入 https://www.e-iceblue.cn/licensing/install-spirepdf-for-java-from-maven-repository.html
【添加Word嵌套表格】
import com.spire.doc.*; import com.spire.doc.documents.*; import com.spire.doc.fields.TextRange; public class NestedTable { public static void main(String[]args){ //加载测试文档 Document doc = new Document("sample.docx"); //获取指定表格中的单元格,并设置行高、列宽 Section sec = doc.getSections().get(0); Table table = sec.getTables().get(0); table.getRows().get(0).setHeight(120f); table.getRows().get(0).getCells().get(0).setWidth(380); //添加嵌套表格到指定单元格 Table nestedtable = table.get(0,0).addTable(true); nestedtable.getTableFormat().setHorizontalAlignment(RowAlignment.Center);//设置嵌套表格在单元格中的对齐方式 nestedtable.resetCells(4,4);//指定嵌套表格行数、列数 nestedtable.autoFit(AutoFitBehaviorType.Auto_Fit_To_Contents);//设置嵌套表格内容自适应方法 //声明表格数组内容 String[][] data ={ new String[]{"编号","产区","最新型号","生产日期",}, new String[]{"1","A","V2.2.0","2019-06-21"}, new String[]{"2","B","V2.6.1","2019-06-18"}, new String[]{"3","C","V2.6.2","2019-06-14"}, }; //填充数组内容到嵌套表格 for (int i = 0; i < data.length; i++) { TableRow dataRow = nestedtable.getRows().get(i); dataRow.getCells().get(i).setWidth(160); dataRow.setHeight(25); dataRow.setHeightType(TableRowHeightType.Exactly); for (int j = 0; j < data[i].length; j++) { dataRow.getCells().get(j).getCellFormat().setVerticalAlignment(VerticalAlignment.Middle); TextRange range = dataRow.getCells().get(j).addParagraph().appendText(data[i][j]); range.getCharacterFormat().setFontName("楷体"); range.getCharacterFormat().setFontSize(11f); range.getOwnerParagraph().getFormat().setHorizontalAlignment(HorizontalAlignment.Center); } } //保存文档 doc.saveToFile("nesedtable1.docx",FileFormat.Docx_2010); } }
嵌套表格效果:
【在Word表格中添加行或者列】
1. 添加行
import com.spire.doc.*; public class AddRow { public static void main(String[] args){ //加载测试文档 Document doc = new Document(); doc.loadFromFile("sample.docx"); //获取表格 Section section = doc.getSections().get(0); Table table = section.getTables().get(0); table.addRow();//默认在表格最下方插入一行 //table.getRows().insert(2,table.addRow());//在表格中第3行插入一行 //table.addRow(4);//默认在表格最下方添加4个单元格 //table.addRow(true,2);//带格式在最后一行添加2个单元格 //table.addRow(false,2);//不带格式在最后一行添加2个单元格 //保存文档 doc.saveToFile("addrow.docx",FileFormat.Docx_2013); doc.dispose(); } }
表格行添加效果:
2. 添加列
import com.spire.doc.*; import com.spire.doc.documents.BorderStyle; import java.awt.*; public class AddColumn { public static void main(String[] args){ //加载测试文档 Document doc = new Document(); doc.loadFromFile("sample.docx"); //获取表格 Section section = doc.getSections().get(0); Table table = section.getTables().get(0); //获取表格单元格宽度及类型 float width = table.get(0,0).getWidth(); CellWidthType type = table.get(0,0).getCellWidthType(); //遍历表格每一行 for (int i = 0; i < table.getRows().getCount(); i++) { TableRow row = table.getRows().get(i);//获取表格每一行 Color color = row.getCells().get(0).getCellFormat().getBackColor();//获取表格单元格背景色 //基于表格每行,在最后添加一个单元格,并设置单元格格式 TableCell cell = row.addCell(true);//默认在最后一列添加单元格 cell.setWidth(width); cell.setCellWidthType(type); cell.getCellFormat().getBorders().setBorderType(BorderStyle.Single); cell.getCellFormat().setBackColor(color); //如需在指定位置插入列,基于以上代码并增加下面一行代码即可 //row.getCells().insert(2,cell);//插入一列作为第三列 } //保存文档 doc.saveToFile("addcolumn.docx", FileFormat.Docx_2013); doc.dispose(); } }
表格列添加效果:
【复制Word表格中的行或者列】
1. 复制行
import com.spire.doc.*; public class CopyRow { public static void main(String[] args) { //加载测试文档 Document doc = new Document(); doc.loadFromFile("test.docx"); //获取表格 Section section = doc.getSections().get(0); Table table =section.getTables().get(0); //复制第三行,并将复制后的行插入到表格作为第五行 TableRow row = table.getRows().get(2).deepClone(); table.getRows().insert(4,row); //保存文档 doc.saveToFile("CopyRow.docx",FileFormat.Docx_2013); doc.dispose(); } }
表格行复制效果:
2. 复制列
import com.spire.doc.*; public class CopyColumn { public static void main(String[] args) { //加载测试文档 Document doc = new Document(); doc.loadFromFile("test.docx"); //获取表格 Section section = doc.getSections().get(0); Table table =section.getTables().get(0); //遍历表格每行 for (int i = 0; i < table.getRows().getCount(); i++) { //复制表格中每行的最后一个单元格,复制 TableRow row = table.getRows().get(i); TableCell cell = (TableCell) row.getCells().getLastItem().deepClone(); //row.getCells().add(cell);//默认在每行最后添加复制后的单元格 row.getCells().insert(2,cell);//在指定位置插入复制后的单元格 } //保存文档 doc.saveToFile("CopyColumn1.docx",FileFormat.Docx_2013); doc.dispose(); } }
表格列复制效果:
【设置Word表格是否禁止跨页断行】
这里通过两种方式来设置防止表格跨页出现断行的效果,供参考。
1. 设置属性禁止跨页断行
import com.spire.doc.*; public class PreventPagebreak { public static void main(String[]args){ //加载测试文档 Document doc= new Document("test.docx"); //获取表格 Table table = doc.getSections().get(0).getTables().get(0); //设置表格是否分页断行 table.getTableFormat().isBreakAcrossPages(false); //保存文档 doc.saveToFile("result.docx",FileFormat.Docx_2013); } }
2. 保持表格内容在同一页面
import com.spire.doc.*; import com.spire.doc.documents.Paragraph; public class PreventPagebreak { public static void main(String[]args){ //加载测试文档 Document doc= new Document("test.docx"); //获取表格 Table table = doc.getSections().get(0).getTables().get(0); //遍历表格单元格 for (int i = 0;i< table.getRows().getCount();i++) { TableRow rows = table.getRows().get(i); for (int j = 0; j< rows.getCells().getCount(); j++){ for (int z= 0; z < rows.getCells().get(j).getParagraphs().getCount();z++){ Paragraph p = rows.getCells().get(j).getParagraphs().get(z); p.getFormat().setKeepFollow(true);//设置表格内容在同一页显示 } } } //保存文档 doc.saveToFile("result1.docx",FileFormat.Docx_2013); } }
出 处:https://www.cnblogs.com/Yesi/p/11691132.html
最新更新
带有参数的装饰器
类装饰器
django中的auth模块与admin后台管理
python的日期处理
字符串常用方法
基本数据类型概述
python-map()函数基本用法
python带你实现任意下载AcFun视频数据~
bbs项目之注册功能
变量的定义和使用
三大常用数据库事务详解之三:事务运行
三大常用关系型数据库事务详解之二:基
三大关系型数据库事务详解之一:基本概
MongoDB常用命令(2)
MongoDB基本介绍与安装(1)
SQLServer触发器调用JavaWeb接口
SQL Server索引的原理深入解析
SqlServer2016模糊匹配的三种方式及效率问题
SQL中Truncate的用法
sqlserver 多表关联时在where语句中慎用tri
VB.NET中如何快速访问注册表
ASP.NET中图象处理过程详解
Vue(1)Vue安装与使用
JavaScript 语言入门
js将一段字符串的首字母转成大写
纯原生html编写的h5视频播放器
H5仿原生app短信验证码vue2.0组件附源码地
TypeScript(4)接口
TypeScript(3)基础类型
TypeScript(2)WebStorm自动编译TypeScript配置