java使用Aspose向word模板写入数据

  Aspose.Words是一个商业.NET类库,能够使得应用程序处理大量的文件任务。Aspose.Words支持Doc,Docx,RTF,HTML,OpenDocument,PDF,XPS,EPUB和其余格式。使用Aspose.Words能够在不使用Microsoft.Word的状况下生成、修改、转换和打印文档。java

一、Aspose在maven下的包引用,例如:web

<dependency>
   <groupId>com.mlsc</groupId>
   <artifactId>aspose-cells</artifactId>
   <version>8.3.1</version>
</dependency>
View Code

二、word模板app

    建立一个word文档,asposeTemplate.docx,内容以下:webapp

 

xxx部门人员信息表maven

 

 

部门名称*ide

$department$post

 

姓名ui

性别this

职务spa

身份证号

联系电话

«TableStart:staffList»«staff»

«name»

«sex»

«post»

«IDNum»

«TableEnd:staffList»«phoneNum»

 

 

   

  说明:文档中的«name»等尖括号内容,是经过菜单的"插入→文档部件→域”找到MergeField并输入相应的域名而来。

三、java代码实现模板填充

 (1)获取模板文件路径

  例如:在webapp/file文件夹下,String templateFilePath = request.getServletContext().getRealPath("") + "/files/asposeTemplate.docx";

(2)获取aspose的许可证

  例如:经过配置的license.xml文件,设置许可

InputStream is = this.getClass().getClassLoader().getResourceAsStream("license.xml"); ByteArrayOutputStream dstStream = null; //填充后的文档输出流
 License aposeLic = new License(); aposeLic.setLicense(is);

  license.xml内容以下:

<License>
  <Data>
    <Products>
      <Product>Aspose.Total for Java</Product>
      <Product>Aspose.Words for Java</Product>
    </Products>
    <EditionType>Enterprise</EditionType>
    <SubscriptionExpiry>20991231</SubscriptionExpiry>
    <LicenseExpiry>20991231</LicenseExpiry>
    <SerialNumber>8bfe198c-7f0c-4ef8-8ff0-acc3237bf0d7</SerialNumber>
  </Data>
  <Signature>sNLLKGMUdF0r8O1kKilWAGdgfs2BvJb/2Xp8p5iuDVfZXmhppo+d0Ran1P9TKdjV4ABwAgKXxJ3jcQTqE/2IRfqwnPf8itN8aFZlV3TJPYeD3yWE7IT55Gz6EijUpC7aKeoohTb4w2fpox58wWoF3SNp6sK6jDfiAUGEHYJ9pjU=</Signature>
</License>
View Code

(3)获取文档对象
  Document doc = new Document(templateFilePath);

(4)填充word模板中$$占位字段

  doc.getRange().replace("$department$", data.getDepartment, true, false); //data.getDepartment 部门名称

(5)填充word模板中«»占位字段

  (a)从数据源获取员工集合,如

List<Staff> staffList = data.getStaffList();

  (b)建立名称为staffList的DataTable,并绑定字段

DataTable staffTable = new DataTable("staffList"); staffTable.getColumns().add("staff"); staffTable.getColumns().add("name"); staffTable.getColumns().add("sex"); staffTable.getColumns().add("post"); staffTable.getColumns().add("IDNum"); staffTable.getColumns().add("phoneNum");

  (c)循环员工集合,构建新的DataTable,填充每个员工的信息

for (int i = 0; i < staffList.size(); i++) {  Staff staff = staffList.get(i);  DataRow row = staffTable.newRow();  row.set(0, "员工信息");  row.set(1, staff.getName());  row.set(2, staff.getSex());  row.set(3, staff.getPost());  row.set(4, staff.getIDNum());  row.set(5, staff.getPhoneNum());  staffTable.getRows().add(row); }

  (d)递归填充,替换文档中mergeField域字段 

doc.getMailMerge().executeWithRegions(staffTable);

  (e)单元格的合并,样式设置

DocumentBuilder builder = new DocumentBuilder(doc); builder.moveToCell(0, 2, 0, 0); //移动到第一个表格的第3行第一个格子(即tableStart) builder.getCellFormat().setVerticalMerge(CellMerge.FIRST); for(int i = 1; i < staffList.size() + 1; i++ ) {  builder.moveToCell(0, 1 + i, 0, 0);  builder.getCellFormat().setVerticalMerge(CellMerge.PREVIOUS); }

  (e)保存并返回文件流

dstStream = new ByteArrayOutputStream(); doc.save(dstStream, saveFormat); return dstStream.toByteArray(); //返回的文件流

 四、填充结果文档

  web项目可经过HttpServletResponse返回下载填充后的文档,例如在controller中,可以下处理

response.setContentType("application/octet-stream; charset=utf-8"); response.setHeader("Content-Disposition", "attachment;  filename=" + URLEncoder.encode(genfileName, "utf-8").replace("+", "%20"));  //genfileName要生成的文件名
 OutputStream out = response.getOutputStream(); out.write(outByte);
View Code

  填充后的文档类容以下图:

相关文章
相关标签/搜索