phpexcel_cell 获取表格样式_Java 操作Word表格——创建嵌套表格、添加/复制表格行或列、设置表格是否禁止跨页断行...

精品推荐

  • 国内稀缺优秀Java全栈课程-Vue+SpringBoot通讯录系统全新发布!

  • Docker快速手上视频教程(无废话版)【免费】

作者:E-iceblue

https://www.cnblogs.com/Yesi/p/11691132.html

本文将对如何在Java程序中操作Word表格作进一步介绍。操作要点包括

  • 如何在Word中创建嵌套表格、

  • 对已有表格添加行或者列

  • 复制已有表格中的指定行或者列

  • 对跨页的表格可设置是否禁止跨页断行

 创建表格,包括添加数据、插入表格、合并单元格、设置表格样式、单元格居中、单元格背景色,单元格字体样式等设置,可参考这篇文章里的内容。


使用工具:Free Spire.Doc for Java (免费版)

Jar文件可通过官网下载jar文件包,下载后,解压文件,将lib文件夹下的Spire.Doc.jar导入Java程序;也可以在maven项目中通过maven仓库安装导入。


【添加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);    }}

嵌套表格效果:

a1a29066c689f77eb4b21a24b48578f1.png

 

【在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();    }}

表格行添加效果:

b3b2507ad841b9138e761392a8d5286a.png

     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();    }}

表格列添加效果:

739c891e1f57cb5a2bb0a059b6d17d5e.png

【复制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();    }}

表格行复制效果:

1da62fc64d7be97d4dc2c8502b3b401d.png

      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();    }}

表格列复制效果:

a43ad6bcbc9f242a2b1879033b7793c6.png

【设置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);    }}

长按关注锋哥微信公众号,非常感谢;

aeb19ddfb79be4150584c398d1e651cd.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值