public static void createContent3(Date adtStart, Date adtEnd,
Map<String, Object> aMap,Map<String, DataTable> mapTables) { DataTable content3_t1 = new DataTable("content3_t1"); //
DataColumnCollection dcc = content3_t1.getColumns(); dcc.add("dw");
dcc.add("id"); DataTable content3_t2 = new DataTable("content3_t2"); //row.getTable();
DataColumnCollection dcc2 = content3_t2.getColumns();
dcc2.add("pid");
dcc2.add("wtdw");
dcc2.add("wzmjs");
dcc2.add("wzsdlds");
dcc2.add("wzfs");
for(int i=0;i<3;i++){
DataRow row = content3_t1.newRow(); //新增一行
row.set(0, "dw"+i); for(int j=0;j<3;j++){
DataRow row2 = content3_t2.newRow(); //新增一行
row2.set(0, "id"+i);
row2.set(1, "wtdw"+i+"-"+j);
row2.set(2, "wzmjs"+i+"-"+j);
row2.set(3, "wzsdlds"+i+"-"+j);
row2.set(4, "wzsdlds"+i+"-"+j);
content3_t2.getRows().add( row2 ); //加入此行数据
}
mapTables.put("content3_t2", content3_t2);
row.set(1, "id"+i);
content3_t1.getRows().add( row ); //加入此行数据
}
mapTables.put("content3_t1", content3_t1); } public static void main(String[] args) throws ParseException { String[] list = new String[1];
list[0]="320402000000"; SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String adtSta="2019-03-01 00:00:00";
String adEnd ="2019-04-01 00:00:00";
Date adtStart = sdf.parse(adtSta);
Date adtEnd = sdf.parse(adEnd); Map<String, Object> mapContents = new HashMap<String, Object>();
Map<String, DataTable> mapTables = new HashMap<String, DataTable>(); createContent3(adtStart, adtEnd, mapContents,mapTables); String path = "D:\\PEES2015\\hop-web\\src\\main\\webapp\\report\\dkt\\dkt-tjfx-zgqk.docx";
String webPath = "\\documents\\rptXCDC_"+HsFileUtil.getUUID()+".doc";
String tPath = "D:\\PEES2015\\hop-web\\src\\main\\webapp" + webPath; System.out.println("Start create Image..."); try {
com.aspose.words.License license = new com.aspose.words.License();
String s = "D:\\PEES2015\\hop-web\\src\\main\\webapp\\report\\";
license.setLicense( s + "lic.xml" );
System.out.println("授权成功");
} catch (Exception e) {
e.printStackTrace();
} //模板文件和将要创建的新文件
String template = path; //可以是doc或docx
String destdoc = tPath; //可以是doc或docx
Document doc;
try{
//第二步 读取word模板文件,可以是.doc或者.docx
doc = new Document( template );
System.out.println("读取word模板文件,可以是.doc或者.docx");
//合并模版,相当于页面的渲染
MailMerge mm = doc.getMailMerge(); // 将 t1 和 t2 关联起来
DataSet ds = new DataSet();
DataTable content3_t1 = mapTables.get("content3_t1");
DataTable content3_t2 = mapTables.get("content3_t2");
ds.getTables().add( content3_t1 );
ds.getTables().add( content3_t2 );
String[] contCols = {"id"};
String[] lstCols = {"pid"};
ds.getRelations().add( new DataRelation("content3_t1t2", content3_t1, content3_t2, contCols, lstCols) );
mm.executeWithRegions(ds); //调用接口 //提供数据源
String[] ks = mapContents.keySet().toArray(new String[0]);//.toArray();//
Object[] vs = mapContents.values().toArray();//.toArray();//
mm.execute(ks, vs);
doc.save( destdoc );
System.out.println("End create Word...");
}catch (Exception e) {
e.printStackTrace();
} Map<String, Object> rlts = Maps.newHashMap();
rlts.put("data", webPath);
System.out.println(rlts);
}

[java 2019-04-09] 代码生成word文档中的表格嵌套问题的更多相关文章

  1. 使用Java POI来选择提取Word文档中的表格信息

    通过使用Java POI来提取Word(1992)文档中的表格信息,其中POI支持不同的ms文档类型,在具体操作中需要注意.本文主要是通过POI来提取微软2003文档中的表格信息,具体code如下(事 ...

  2. C# 在word文档中复制表格并粘帖到下一页中

    C# 在word文档中复制表格并粘帖到下一页中 object oMissing = System.Reflection.Missing.Value;            Microsoft.Offi ...

  3. 2018-10-04 [日常]用Python读取word文档中的表格并比较

    最近想对某些word文档(docx)的表格内容作比较, 于是找了一下相关工具. 参考Automate the Boring Stuff with Python中的word部分, 试用了python-d ...

  4. 将表格添加到Word文档中 ,包括表格样式设置

    创建 Table 对象并设置其属性 在您将表格插入文档之前,必须创建 Table 对象并设置其属性. 要设置表格的属性,请创建TableProperties对象并为其提供值. TablePropert ...

  5. Java jacob调用打印机打印word文档

    前面说了Java如何生成复杂的Word文档,今年记录下Java如何调用打印机打印word文档. 起初用的是自带的PrintJob,但是系统提供的打印机制并不成熟完整.网上的代码也是千篇一律,在我的打印 ...

  6. Java 用Freemarker完美导出word文档(带图片)

    Java  用Freemarker完美导出word文档(带图片) 前言 最近在项目中,因客户要求,将页面内容(如合同协议)导出成word,在网上翻了好多,感觉太乱了,不过最后还是较好解决了这个问题. ...

  7. 用java语言通过POI实现word文档的按标题提取

    最近有一个项目需要将一个word文档中的数据提取到数据库中.就去网上查了好多资料,最靠谱的就是用poi实现word文档的提取. 喝水不忘挖井人,我查了好多资料就这个最靠谱,我的这篇博客主要是借鉴htt ...

  8. Java 在 Word 文档中使用新文本替换指定文本

    创作一份文案,经常会高频率地使用某些词汇,如地名.人名.人物职位等,若表述有误,就需要整体撤换.文本将介绍如何使用Spire.Doc for Java,在Java程序中对Word文档中的指定文本进行替 ...

  9. 如何通过 Java 代码隐藏 Word 文档中的指定段落

    在编辑Word文档时,我们有时需要将一些重要信息保密. 因此,可以隐藏它们以确保机密性. 在本文中,将向您介绍如何通过 Java 程序中的代码隐藏 Word 文档中的特定段落.下面是我整理的具体步骤, ...

随机推荐

  1. 测试那些事儿—selenium IDE 自动化测试

    浏览器 Firefox Setup 35.0.1 安装完成后设置菜单栏 关闭浏览器自动更新 插件配置(必备武器) FireBug Firebug是firefox下的一个扩展,能够调试所有网站语言,如H ...

  2. Linux中(Ubuntu18.04.x/CentOS)mysql8.0.x安装/配置/部署/启动

    The MySQL Connectors and APIs are the drivers and libraries that you use to connect applications in ...

  3. appium---android元素定位

    原文链接:https://www.cnblogs.com/meitian/p/6103391.html 一.常用识别元素的工具 uiautomator:Android SDK自带的一个工具,在tool ...

  4. java 删除多层文件夹

    /** * 因为不小心,写了一个死循环,在电脑里创建的了n多层空文件夹 * 并且手动最外层删除不掉. * 所以用写了本代码,从里向外的进行删除操作. * @author Singularity * @ ...

  5. C#实现按键计算器功能2(增强版)

    1.   实验目的 (  1)熟悉C#语言的使用和语法知识 2.   实验要求 (1)设计简单的含交互界面的计算器软件,具有较强的用户体验感. (2)使用C#语言进行编程,创建窗体应用程序. (3)实 ...

  6. python基础(七)

    一.接口开发 import pymysql def my_db(sql): conn = pymysql.connect( host='118.24.3.40', user='jxz', passwo ...

  7. Pycharm桌面图标(Fedora)

    1.解压pycharm压缩包至/usr/local/pycharm文件夹下 2.在/usr/share/applications/目录下,新建Pycharm.desktop文件,内容如下: [Desk ...

  8. python,pil库的小应用

    <pre>#euraxluo 5.15 #obj_1#跳一跳的外挂 from PIL import Image import subprocess import time import r ...

  9. Battle Zone 战争地带

    发售年份 1980 平台 街机 开发商 雅达利(Atari) 类型 射击 https://www.youtube.com/watch?v=Ctr54kopo8I

  10. Java小代码

    1. public class test1 {public static void main(String[] args) { Person P = new Person("gdsgds&q ...