pageoffice在线打开word文件生成表格

转载:数据区域生成表格

# 数据区域生成表格

注意

本文中展示的代码均为关键代码,复制粘贴到您的项目中,按照实际的情况,例如文档路径,用户名等做适当修改即可使用。

在实际项目的开发中会遇到这样的需求:要求在生成word文件的时候,在文件的指定位置动态生成表格并填充。

public Table createTable(int numRows,
                         int numColumns,
                         WdAutoFitBehavior autoFitBehavior)
                  throws java.lang.Exception

参数:

  • numRows 新表格的行数。
  • numColumns 新表格的列数。
  • autoFitBehavior 用于设置 Word 调整表格大小的“自动调整”规则。

数据区域生成表格通常有两种使用场景:

  1. 在word文档已有的指定的数据区域位置动态生成表格。
Java
//在word中指定的"PO_table1"的数据区域内动态创建一个3行5列的表格
Table table1 = doc.openDataRegion("PO_table1").createTable(3, 5, WdAutoFitBehavior.wdAutoFitWindow);
.Net Core
//在word中指定的"PO_table1"的数据区域内动态创建一个3行5列的表格
PageOfficeNetCore.WordWriter.Table table1 = 
      doc.OpenDataRegion("PO_table1").CreateTable(3, 5, PageOfficeNetCore.WordWriter.WdAutoFitBehavior.wdAutoFitWindow);
  1. 在 word 文档开始或者末尾处动态生成表格。这种场景就需要依赖 PageOffice 预留的两个特殊数据区域:[HOME]和[END]动态创建数据区域,然后根据新生成的数据区域动态生成表格。
Java
//在word文档的末尾处动态创建一个3行5列的表格。具体代码步骤是先根据PageOffice预留[END]数据区域动态创建"PO_table1",然后在"PO_table1"处动态创建3行5列的表格。
Table table1 = doc.createDataRegion("PO_table1",DataRegionInsertType.After, "[END]").createTable(3, 5, WdAutoFitBehavior.wdAutoFitWindow);
.Net Core
//在word文档的末尾处动态创建一个3行5列的表格。具体代码步骤是先根据PageOffice预留[END]数据区域动态创建"PO_table1",然后在"PO_table1"处动态创建3行5列的表格。
PageOfficeNetCore.WordWriter.Table table1 =
      doc.CreateDataRegion("PO_table1", PageOfficeNetCore.WordWriter.DataRegionInsertType.After, "[END]").CreateTable(3, 5, PageOfficeNetCore.WordWriter.WdAutoFitBehavior.wdAutoFitWindow);

# 后端代码

例如:在当前 word 文件的末尾处生成一个 3 行 5 列的表格并动态填充。

Java
PageOfficeCtrl poCtrl = new PageOfficeCtrl(request);
WordDocument doc = new WordDocument();
DataRegion dr = doc.createDataRegion("PO_table1",DataRegionInsertType.After, "[END]");
Table table1 = dr.createTable(3, 5, WdAutoFitBehavior.wdAutoFitWindow);
for (int i = 1; i < 4; i++) {
    table1.openCellRC(i, 1).setValue("AA" + String.valueOf(i));
    table1.openCellRC(i, 2).setValue("BB" + String.valueOf(i));
    table1.openCellRC(i, 3).setValue("CC" + String.valueOf(i));
    table1.openCellRC(i, 4).setValue("DD" + String.valueOf(i));
    table1.openCellRC(i, 5).setValue("EE" + String.valueOf(i));
}
poCtrl.setWriter(doc);
//打开Word文件
poCtrl.webOpen("D:\\template1.docx", OpenModeType.docNormalEdit, "张三");
.Net Core
PageOfficeNetCore.PageOfficeCtrl POCtrl = new PageOfficeNetCore.PageOfficeCtrl(Request);
PageOfficeNetCore.WordWriter.WordDocument doc = new PageOfficeNetCore.WordWriter.WordDocument();
PageOfficeNetCore.WordWriter.DataRegion dr = wordDoc.CreateDataRegion("PO_table1", PageOfficeNetCore.WordWriter.DataRegionInsertType.After, "[END]");
PageOfficeNetCore.WordWriter.Table table1 = dr.CreateTable(3, 5, PageOfficeNetCore.WordWriter.WdAutoFitBehavior.wdAutoFitWindow);
for (int i = 1; i < 4; i++)
{
    table1.OpenCellRC(i, 1).Value = "AA" + i.ToString();
    table1.OpenCellRC(i, 2).Value = "BB" + i.ToString();
    table1.OpenCellRC(i, 3).Value = "CC" + i.ToString();
    table1.OpenCellRC(i, 4).Value = "DD" + i.ToString();
    table1.OpenCellRC(i, 5).Value = "DD" + i.ToString();
}
POCtrl.SetWriter(doc);
//打开Word文档
POCtrl.WebOpen("D:\\template1.docx", PageOfficeNetCore.OpenModeType.docNormalEdit, "tom");

# 前端代码

本示例无前端关键代码。

posted @ 2024-04-18 13:31  爱吃苹果皮  阅读(56)  评论(0编辑  收藏  举报