aspose java_Java按模板导出Excel———基于Aspose实现

本文介绍了在Java环境下,使用Aspose库按模板导出Excel的方法。包括设置开发环境,如JDK、Maven、SpringBoot和Aspose版本。详细展示了如何引入Aspose的jar包,校验许可证,创建AsposeUtils工具类进行模板导出,并提供了测试案例验证导出功能。同时,提到了模板中的占位符使用。
摘要由CSDN通过智能技术生成

开发环境

jdk 1.8

Maven 3.6

SpringBoot 2.1.4.RELEASE

aspose-cells 8.5.2

Idea

先看效果

模板:

06eb8327b32a0fbead0a2da745d61117.png

导出后效果:

e49ac16a2de3b2d3faa40469e49784fc.png

引入jar包

pom.xml

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

com.aspose

aspose-cells

8.5.2

AsposeJavaAPI

Aspose Java API

http://repository.aspose.com/repo/

校验许可证

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

运行程序时,只能打开100个Excel文件。如果您的应用程序超过此数量,将引发异常。

带有评估水印的工作表

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

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

在resources包下添加license.xml

215d7cc7c6e11810624ee176277a8e3b.png

创建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 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 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;

}

a169155a4ed1b00f4d36eb98455b2444.png

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

占位符

常规占位 (¬_¬)…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值