开发环境

  1. jdk 1.8
  2. Maven 3.6
  3. SpringBoot 2.1.4.RELEASE
  4. aspose-cells 8.5.2
  5. Idea

参照: 基于SpringBoot构建分模块项目

先看效果

模板:

导出后效果:

引入jar包

pom.xml

如遇到jar无法下载的情况,可自行下载到本地,然后手动添加到项目中

    <dependencies>
<!-- 你的其他jar --> <!-- aspose -->
<dependency>
<groupId>com.aspose</groupId>
<artifactId>aspose-cells</artifactId>
<version>8.5.2</version>
</dependency>
</dependencies> <repositories>
<repository>
<id>AsposeJavaAPI</id>
<name>Aspose Java API</name>
<url>http://repository.aspose.com/repo/</url>
</repository>
</repositories>

校验许可证

Aspose默认引入的是评估版(未指定许可证),此版本可使用全部功能,但是有以下两个限制:

  • 运行程序时,只能打开100个Excel文件。如果您的应用程序超过此数量,将引发异常。
  • 带有评估水印的工作表

如果你的应用场景不能接受以上两点限制,可在官网购买许可证,然后通过校验许可证解除限制;如果你可以接受,请忽略此操作;

官网提供多种校验方式,此处只列举其中一种将License配置在项目中

在resources包下添加license.xml

创建AsposeUtils工具类,添加方法校验方法

package com.wayne.common.utils;

import com.aspose.cells.License;
import java.io.InputStream; /**
* Aspose工具类
* @author Wayne
* @date 2019/6/10
*/
public class AsposeUtils { /**
* 校验Aspose的License
*/
private static Boolean checkLicense() {
try {
InputStream license = AsposeUtils.class.getClassLoader().getResourceAsStream("license.xml");
License aposeLic = new License();
aposeLic.setLicense(license);
} catch (Exception e) {
e.printStackTrace();
}
return License.isLicenseSet();
}
}

导出方法

此处列举为较简单的单个sheet,且不分页导出,更多使用方式请参考官网文档

package com.wayne.common.utils;

import com.aspose.cells.License;
import com.aspose.cells.Workbook;
import com.aspose.cells.WorkbookDesigner; import java.io.InputStream;
import java.util.List; /**
* Aspose工具类
* @author Wayne
* @date 2019/6/10
*/
public class AsposeUtils { /**
* @param head 单个对象,将对象作为此参数传入。如没有,传入null
* @param list 多个对象时,将对象作为此参数传入。如没有,传入null
* @param templateName 模板所在的位置,如:E:/template/studentTemplate.xlsx
* @param resultFilePath 生成后的文件所存放的文件夹,如:E:/data/
* @return 生成后的文件路径及文件名,如:E:/data/student.xlsx
*/
public static <H> String exportExcelByAsposeWithTemplate(H head, List list, String templateName, String resultFilePath) {
// 校验许可证
if(!checkLicense()) {
return null;
}
// 生成后文件名
String resultFile = resultFilePath + System.currentTimeMillis() + ".xlsx"; try {
// 加载模板
Workbook wb = new Workbook(templateName);
// 加载设计器
WorkbookDesigner designer = new WorkbookDesigner();
designer.setWorkbook(wb);
// 单个对象和集合区分(在模板中定义方式不同)
if(null != head) {
designer.setDataSource("Head", head);
}
if(null != list) {
designer.setDataSource("List", list);
} designer.process();
wb.save(resultFile);
wb.dispose();
} catch (Exception e) {
e.printStackTrace();
}
return resultFile;
} /**
* 校验Aspose的License
*/
private static Boolean checkLicense() {
try {
InputStream license = AsposeUtils.class.getClassLoader().getResourceAsStream("license.xml");
License aposeLic = new License();
aposeLic.setLicense(license);
} catch (Exception e) {
e.printStackTrace();
}
return License.isLicenseSet();
}
}

测试结果

@Test
public void exportExcelByAsposeWithTemplateTestCase() {
String templateName = "E:/Temp/Template.xlsx";
String resultFilePath = "E:/Temp/"; // 单个对象测试
UserOne userOne = new UserOne();
userOne.setId(1);
userOne.setUsername("Tom");
userOne.setPassword("123123"); // 集合测试
List<UserTwo> lists = new ArrayList<>();
for(int i = 0; i < 10; i++) {
UserTwo temp = new UserTwo();
temp.setId(i*10);
temp.setUsername(String.valueOf((i*100)));
lists.add(temp);
} String resultFileName = AsposeUtils.exportExcelByAsposeWithTemplate(userOne, lists, templateName, resultFilePath);
assert null != resultFileName;
}

运行测试用例,绿了~~~

占位符

常规占位 (¬_¬)…

Java按模板导出Excel———基于Aspose实现的更多相关文章

  1. Java无模板导出Excel,Apache-POI插件实现

    开发环境 jdk 1.8 Maven 3.6 Tomcat 8.5 SpringBoot 2.1.4.RELEASE Apache-POI 3.6 Idea 注意: 我是在现有的基于SpringBoo ...

  2. java五行代码导出Excel

    目录 先看代码 再看效果 EasyExcel 附: Java按模板导出Excel---基于Aspose实现 Java无模板导出Excel,Apache-POI插件实现 已经写过两种Excel导出插件了 ...

  3. aspose.cells根据模板导出excel

    又隔十多天没写博客了,最近都在忙项目的事情,公司人事变动也比较大,手头上就又多了一个项目.最近做用aspose.cells根据模板导出excel报价单的功能,顺便把相关的核心记下来,先上模板和导出的效 ...

  4. 关于Java中excel表格导出的总结(Java程序导出模板和Java根据模板导出表格两种实现方式)

    导出excel通用模板(程序定义模板导出) 转载原文:https://www.jianshu.com/p/5c7b359a159c 如下代码,本方法主要用于程序定义模板格式,并导出文件.该方法将定义和 ...

  5. java使用jxls导出Excel

    jxls是基于POI的Excel模板导出导入框架.通过使用类似于jstl的标签,有效较少导出Excel的代码量. 1.pom <!-- https://mvnrepository.com/art ...

  6. POI通过模板导出EXCEL文件

    一般的EXCEL导出使用POI先创建一个HSSFWorkbook,然后通过不断创建HSSFRow,HSSFCell后设置单元格内容便可以完成导出. 这次在项目中需要用到模板,导出的内容包括(1.模板中 ...

  7. Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类

    Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类 ============================== ©Copyright 蕃薯耀 20 ...

  8. ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案 try.dot.net 的正确使用姿势 .Net NPOI 根据excel模板导出excel、直接生成excel .Net NPOI 上传excel文件、提交后台获取excel里的数据

    ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案   ASP.NET Core 从2.2版本开始,采用了一个新的名为Endpoint的路由方案,与原来的方案在使用上差别不 ...

  9. apache poi根据模板导出excel

    需要预先新建编辑好一个excel文件,设置好样式. 编辑好输出的数据,根据excel坐标一一对应. 支持列表数据输出,列表中列合并. 代码如下: package com.icourt.util; im ...

随机推荐

  1. Mysql异常_01_ 誓死登进mysql_Can't connect to MySQL server on 'localhost' (10061)

    现象:打开cmd,输入命令:mysql -uroot -p 回车之后,输入密码,结果进不去mysql,并且抛出异常 异常:Can't connect to MySQL server on 'local ...

  2. PHP把时间转换成几分钟前、几小时前、几天前的几个函数、类分享

    这篇文章主要介绍了php计算时间几分钟前.几小时前.几天前的几个函数.类分享,需要的朋友可以参考下一.函数实现实例1: <?php header("Content-type: text ...

  3. 基于T4的生成方式

    一.什么是T4模板 T4是对“Text Template Transformation Toolkit”(4个T)的简称.是一个基于文本文件转换的工具包.T4的核心是一个基于“文本模板”的转换引擎(以 ...

  4. hdp 集群问题解决记录

    2019-04-23 14:16:21,769 WARN namenode.FSImage (EditLogFileInputStream.java:scanEditLog(359)) - Caugh ...

  5. 使用NSURLProtocol和NSURLSession拦截UIWebView的HTTP请求(包括ajax请求)

    问题:服务器端有一个网站需要AD认证,整站都开了Basic认证,包括图片,CSS等资源,我在HTTP请求头里面添加认证所需的用户名和密码,传递到服务器端可以认证通过.我在UIWebView的shoul ...

  6. html之canvas

    canvas代码片段: <canvas id="testCanvas" width="400" height="150" style= ...

  7. myeclipse保存时弹出Building workspace

    最近做项目,每次保存修改的东西.myeclipse都会building workspace(重新编译)一下.并且那 building的速度真不够慢的啊. 严重影响编程速度. 在网上也发现遇到此问题的很 ...

  8. Centos7 忘记密码的情况下,修改root或其他用户密码

    转载:https://blog.csdn.net/wcy00q/article/details/70570043 应用场景 linux管理员忘记root密码,需要进行找回操作. 注意事项:本文基于ce ...

  9. Selenium并行启动多个浏览器

    如果你对 Selenium 自动化测试已经非常熟悉,你仅仅需要一个快速上手来使程序运行起来.本章节的内容能满足不同的技术层次,但是如果你仅仅需要一个可以快速上手的指引,那么就显得有点多.如果是这样,你 ...

  10. 【255】◀▶IEW-Unit20

    Unit 20 Environment: Tourism I.定语从句及分词在雅思写作中的运用 定语从句: 1. 先行词 2. 关系词:关系代词.关系副词 3. 非限制性定语从句 4. 分词和定语从句 ...