使用POI生成word文档的table表格

本文详细介绍了如何通过ApachePOI库在Word文档中创建和操作表格,包括一行一列、固定行列的table生成,以及处理table合并列的问题,并提供了代码示例和解决创建多table时的合并问题的方法。
摘要由CSDN通过智能技术生成

使用POI生成word文档的table表格

1. 引入maven依赖

		<dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>4.1.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml-schemas</artifactId>
            <version>4.1.2</version>
        </dependency>

2. 生成table的两种方式介绍

2.1 生成一行一列的table

//生成一行一列的table
XWPFTable table = document.createTable();
//添加列
table.getRow(0).addNewTableCell();
//添加行(添加的新行默认就是总共的列数)
table.createRow();

测试Demo:CreateTableDemo1.java

package com.poi.word.demo;


import org.apache.poi.xwpf.usermodel.*;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.STMerge;

import java.io.FileOutputStream;

public class CreateTableDemo1 {
    public static void main(String[] args) throws Exception {
        XWPFDocument document = new XWPFDocument();

        //默认创建一行一列table
        XWPFTable table = document.createTable();
        table.setWidth("100%");

        XWPFTableRow first_row = table.getRow(0);
        XWPFTableCell first_Row_first_Cell = first_row.getCell(0);
        first_Row_first_Cell.setText("我是第一行第一列");

        //第一行添加一列
        first_row.addNewTableCell().setText("我是第一行第二列");

        //创建第二行
        XWPFTableRow snd_row = table.createRow();
        snd_row.getCell(0).setText("第二行,第一列");
        snd_row.getCell(1).setText("第二行,第二列");

        //创建第三行
        XWPFTableRow trd_row = table.createRow();
        XWPFParagraph trd_row_first_paragraph = trd_row.getCell(0).getParagraphs().get(0);
        XWPFRun trdRowFirstCellRun = trd_row_first_paragraph.createRun();
        trdRowFirstCellRun.setFontSize(14);
        trdRowFirstCellRun.setBold(true);
        trdRowFirstCellRun.setText("第三行,第一列");

        trd_row.getCell(1).setText("第三行,第二列");

        //创建第四行
        XWPFTableRow row4 = table.createRow();
        row4.getCell(0).getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.RESTART);
        row4.getCell(1).getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.CONTINUE);
        row4.getCell(0).setText("第四行");

        FileOutputStream out = new FileOutputStream("D:\\poiword\\create_table1.docx");
        document.write(out);
        out.close();
        document.close();
    }
}

生成结果:
在这里插入图片描述

2.2 生成固定行列的table

//生成3行5列的table
XWPFTable table2 = document.createTable(3, 5);

测试Demo:

package com.poi.word.demo;


import org.apache.poi.xwpf.usermodel.XWPFDocument;
import org.apache.poi.xwpf.usermodel.XWPFRun;
import org.apache.poi.xwpf.usermodel.XWPFTable;
import org.apache.poi.xwpf.usermodel.XWPFTableRow;

import java.io.FileOutputStream;

public class CreateTableDemo2 {

    public static void main(String[] args) throws Exception {
        XWPFDocument document = new XWPFDocument();
        XWPFTable table2 = document.createTable(3, 5);
        table2.setWidth("100%");
        for(int i=0; i<3; i++){
            XWPFTableRow t2tRow = table2.getRow(i);
            for(int j=0; j<5; j++){
                if(i==1){
                    XWPFRun t2Row2Run = t2tRow.getCell(j).getParagraphs().get(0).createRun();
                    t2Row2Run.setFontSize(10);
                    t2Row2Run.setBold(true);
                    t2Row2Run.setText("第"+(i+1)+"行,第"+(j+1)+"列");
                }else{
                    t2tRow.getCell(j).setText("第"+(i+1)+"行,第"+(j+1)+"列");
                }

            }
        }

        FileOutputStream out = new FileOutputStream("D:\\poiword\\create_table2.docx");
        document.write(out);
        out.close();
        document.close();
    }
}

生成结果:
在这里插入图片描述

2.3 table合并列

row4.getCell(0).getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.RESTART);
row4.getCell(1).getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.CONTINUE);

2.4 创建多个table存在的问题

在这里插入图片描述
创建的两个table输出时候合并成了一个table,而且第一个table的宽度也变成了第二个table前两列的宽度。

解决方法:

  1. 添加空段落
    XWPFParagraph paragraph1 = document.createParagraph();
  2. 添加分页(会让两个table在不同的页面)
    document.createParagraph().setPageBreak(true); document.createParagraph().createRun().addBreak(BreakType.PAGE);//推荐方式

添加空段落的解决方法Demo:

package com.poi.word.demo;


import org.apache.poi.xwpf.usermodel.*;

import java.io.FileOutputStream;

public class GenWordTableDemo2 {

    public static void main(String[] args) throws Exception {
        XWPFDocument document = new XWPFDocument();

        //默认创建一行一列table
        XWPFTable table = document.createTable();
        table.setWidth("100%");

        XWPFTableRow first_row = table.getRow(0);
        XWPFTableCell first_Row_first_Cell = first_row.getCell(0);
        first_Row_first_Cell.setText("我是第一行第一列");

        //第一行添加一列
        first_row.addNewTableCell().setText("我是第一行第二列");

        //创建第二行
        XWPFTableRow snd_row = table.createRow();
        snd_row.getCell(0).setText("第二行,第一列");
        snd_row.getCell(1).setText("第二行,第二列");

        //创建第三行
        XWPFTableRow trd_row = table.createRow();
        XWPFParagraph trd_row_first_paragraph = trd_row.getCell(0).getParagraphs().get(0);
        XWPFRun trdRowFirstCellRun = trd_row_first_paragraph.createRun();
        trdRowFirstCellRun.setFontSize(14);
        trdRowFirstCellRun.setBold(true);
        trdRowFirstCellRun.setText("第三行,第一列");

        trd_row.getCell(1).setText("第三行,第二列");

        XWPFParagraph paragraph1 = document.createParagraph();

        //分页的两种方式
        //document.createParagraph().setPageBreak(true);
        //document.createParagraph().createRun().addBreak(BreakType.PAGE);//推荐方式

        /**
         * 第2个table
         */
        XWPFTable table2 = document.createTable(3, 5);
        table2.setWidth("100%");
        XWPFTableRow t2FirstRow = table2.getRow(0);
        for(int i=0; i<3; i++){
            XWPFTableRow t2tRow = table2.getRow(i);
            for(int j=0; j<5; j++){
                if(i==1){
                    XWPFRun t2Row2Run = t2tRow.getCell(j).getParagraphs().get(0).createRun();
                    t2Row2Run.setFontSize(10);
                    t2Row2Run.setBold(true);
                    t2Row2Run.setText("第"+(i+1)+"行,第"+(j+1)+"列");
                }else{
                    t2tRow.getCell(j).setText("第"+(i+1)+"行,第"+(j+1)+"列");
                }

            }
        }

        FileOutputStream out = new FileOutputStream("D:\\poiword\\gen_word2.docx");
        document.write(out);
        out.close();
        document.close();

    }
}

效果:
在这里插入图片描述

### 回答1: 要使用POI获取Word文档表格的数据,可以按照以下步骤进行: 1. 首先,使用POI库打开Word文档。例如,使用XWPFDocument类打开.docx文件。 ```java FileInputStream fis = new FileInputStream("example.docx"); XWPFDocument doc = new XWPFDocument(fis); ``` 2. 然后,使用getTables()方法获取文档中的所有表格,该方法返回一个XWPFTable的List。 ```java List<XWPFTable> tables = doc.getTables(); ``` 3. 对于每个表格使用getRows()方法获取表格中的所有行,该方法返回一个XWPFTableRow的List。 ```java for(XWPFTable table : tables) { List<XWPFTableRow> rows = table.getRows(); for(XWPFTableRow row : rows) { // 处理行数据 } } ``` 4. 对于每一行,使用getTableCells()方法获取该行中的所有单元格,该方法返回一个XWPFTableCell的List。 ```java for(XWPFTable table : tables) { List<XWPFTableRow> rows = table.getRows(); for(XWPFTableRow row : rows) { List<XWPFTableCell> cells = row.getTableCells(); for(XWPFTableCell cell : cells) { // 处理单元格数据 } } } ``` 5. 对于每个单元格,使用getText()方法获取单元格中的文本内容。 ```java for(XWPFTable table : tables) { List<XWPFTableRow> rows = table.getRows(); for(XWPFTableRow row : rows) { List<XWPFTableCell> cells = row.getTableCells(); for(XWPFTableCell cell : cells) { String text = cell.getText(); // 处理单元格中的文本内容 } } } ``` 这样就可以获取Word文档中所有表格的所有行和单元格的数据了。 ### 回答2: 使用Java利用POI获取Word文档表格中的数据,可以通过以下步骤实现: 1. 导入POI库:首先需要在Java项目中导入POI库,并将库文件添加到项目的classpath中。 2. 加载Word文档使用POI的XWPFDocument类加载Word文档,代码如下: ```java InputStream in = new FileInputStream("path/to/word/document.docx"); XWPFDocument doc = new XWPFDocument(in); ``` 3. 获取所有表格:通过getTables()方法获取Word文档中的所有表格,代码如下: ```java List<XWPFTable> tables = doc.getTables(); ``` 4. 遍历表格:可以使用循环遍历所有表格,根据需要进行操作,例如获取表格中的数据等。 ```java for (XWPFTable table : tables) { // 获取表格的行 List<XWPFTableRow> rows = table.getRows(); // 遍历行 for (XWPFTableRow row : rows) { // 获取行的单元格 List<XWPFTableCell> cells = row.getTableCells(); // 遍历单元格 for (XWPFTableCell cell : cells) { // 获取单元格中的内容 String content = cell.getText(); // 处理单元格数据,例如打印或保存到其他地方 System.out.println(content); } } } ``` 通过以上步骤,可以使用Java利用POI获取Word文档表格中的数据。根据实际需求,可以对获取到的数据进行处理,例如保存到数据库或生成其他格式的文档。 ### 回答3: Java利用POI可以很方便地获取Word文档表格中的数据。下面是实现的步骤: 1. 导入POI库:首先需要在Java工程中导入POI的相关库文件,可以使用Maven或手动下载并导入。 2. 创建Word文档对象:使用XWPFDocument类创建一个Word文档对象,打开需要解析的Word文档。 3. 获取文档中的表格使用getTables()方法获取文档中所有的表格,返回一个List对象。 4. 遍历表格使用for循环遍历表格列表,可以通过getTable()方法获取每个表格。 5. 获取表格中的行并遍历:使用getRows()方法获取表格中所有的行,返回一个List对象。然后使用for循环遍历行列表,可以通过getRow()方法获取每一行。 6. 获取行中的单元格并遍历:使用getTableCells()方法获取行中所有的单元格,返回一个List对象。然后使用for循环遍历单元格列表,可以通过getTableCell()方法获取每个单元格。 7. 获取单元格中的文本:使用getText()方法获取单元格中的文本内容。 完整的示例代码如下: ```java import org.apache.poi.xwpf.usermodel.*; import java.io.FileInputStream; import java.io.IOException; import java.util.List; public class ReadTableData { public static void main(String[] args) { try { // 创建Word文档对象 XWPFDocument document = new XWPFDocument(new FileInputStream("example.docx")); // 获取文档中的所有表格 List<XWPFTable> tables = document.getTables(); // 遍历表格 for (XWPFTable table : tables) { // 获取表格中的所有行 List<XWPFTableRow> rows = table.getRows(); // 遍历行 for (XWPFTableRow row : rows) { // 获取行中的所有单元格 List<XWPFTableCell> cells = row.getTableCells(); // 遍历单元格 for (XWPFTableCell cell : cells) { // 获取单元格中的文本内容 String text = cell.getText(); System.out.println(text); } } } // 关闭文档 document.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` 以上就是使用POI库获取Word文档表格中数据的基本步骤和示例代码。通过POI的各种API可以更加灵活地处理表格中的数据,比如可以合并、拆分单元格,修改样式等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值