简介

相信大家能经常性的遇到项目上各类excel的导出,简单的excel格式,用简单的poi,easyExcel等工具都能导出。但是针对复杂的excel,有固定的样式、合并单元格、动态列等各类要求,导致excel 导出需要花很大一部分精力去写代码。jxls在很大程度上解决了以上问题。

这里简单介绍下jxls,JXLS是国外一个简单的、轻量级的excel导出库,链接:JXLS官网,这里有详细的文档说明教程(英文版),为了方便大家使用,我举例几个常见的excel模板配置,方便大家使用。

引入Maven依赖

org.jxls
jxls
2.11.0

org.jxls
jxls-poi
2.11.0

org.jxls
jxls-jexcel
${jxlsJexcelVersion}

后台代码

工具类:JxlsUtils,导出静态方法

public static void exportExcel(InputStream is, OutputStream os, Map model) throws IOException {
Context context = new Context();
if (model != null) {
for (String key : model.keySet()) {
context.putVar(key, model.get(key));

JxlsHelper jxlsHelper = JxlsHelper.getInstance();
Transformer transformer = jxlsHelper.createTransformer(is, os);
JexlExpressionEvaluator evaluator = (JexlExpressionEvaluator) transformer.getTransformationConfig()
.getExpressionEvaluator();
Map funcs = new HashMap();
funcs.put("utils", new JxlsUtils()); // 添加自定义功能
evaluator.setJexlEngine(new JexlBuilder().namespaces(funcs).create());
jxlsHelper.processTemplate(context, transformer);

导出controller

//导出示例Controller
@PostMapping("/export/exportTradeCreditData")
@ResponseBody
public void exportTradeCreditData(HttpServletRequest request, HttpServletResponse response, Date countDate) {
String templatePath = "template/excel/trade_credit_data.xlsx";
//查找模板文件路径,这里PathTools类为系统内部封装类,大家注意copy
URL templateResource = PathTools.findResource(templatePath);
try (OutputStream out = response.getOutputStream();
InputStream templateStream = templateResource.openStream();) {
//业务数据查询
List list = countingReportService.queryTradeCreditData(countDate);

//excel模板内,数据组装
Map map = new HashMap();
map.put("year", getYear(countDate));
map.put("contracts", list);
JxlsUtils.exportExcel(templateStream, out, map);
out.close();
} catch (Exception e) {
e.printStackTrace();
log.error("导出excel异常, {}", JxlsUtils.executeException(e));
}
}
创建模版

  • 新建excel模板,xlsx格式

  • 工作表中按照的导出要求,设置表格样式

  • 仅限于简单的表头与行、列的宽度、高度

  • 编写写表达式,在工作表中右键插入批注,office中添加批注快捷键(Shit + F2)

  • 设置区域、数据行、合并单元格、动态列等

XLS表达式

简单列举常用的几个表达式

jx:areajx:area(lastCell = "H3")

XLS Area 是JxlsPlus中的一个重要概念,它表明excel模板中须要被解析的矩形区域,由A1到最后一个单元格表示,有利于加快解析速度。它须要被定义在excel 模板的第一个单元格(A1)。另外,推荐Java划水摸鱼网址:https://www.yoodb.com/ 即将上线

示例图:

打开网易新闻 查看精彩图片

jx:each 最常用的xls表达式jx:each(items="contracts" var="contract" lastCell="H3")

  • items:上下文中集合的变量名;

  • var:在遍历集合的时候每一条记录的变量名;

  • area:该XLS Command的解析区域;

  • direction:数据在excel中填充的方向,默认(DOWN)向下;

  • select:其值为一个表达式,用来过滤数据

jx:each(items="countMonths" var="month" lastCell="C3" direction="RIGHT")

简单的示例图:

打开网易新闻 查看精彩图片

复杂的示例图:

打开网易新闻 查看精彩图片

jx:mergeCells 合并单元格jx:mergeCells(lastCell="合并单元格范围"
[, cols="合并的列数"]
[, rows="合并的行数"]
[, minCols="要合并的最小列数"]
[, minRows="要合并的最小行数"]

  • lastCell:合并单元格范围;

  • cols:合并的列数;

  • rows:合并的行数;

  • minCols:要合并的最小列数;

  • minRows:要合并的最小行数;

示例图:

打开网易新闻 查看精彩图片

动态列-综合使用jx:each(items="countMonths" var="month" lastCell="C3" direction="RIGHT")

这里还是通过jx:each来使用,不同的是direction 属性的值为:RIGHT(向右),默认为:DOWN(向下)。

示例截图:

打开网易新闻 查看精彩图片

以上截图中几个参数说明:

  • countMonths:动态列集合,month为集合循环的实体,取值为:${month}

  • contracts:行数据集合,contract、colData 都是集合循环的实体,取值为:${contract.custName}等

  • colData.monthData.get(month):动态列的数据,根据列名去匹配实体字段

  • ${empty()}:判断集合对应动态列数据 是否为空,做好判断,写入数据

动态列数据行的数据获取:

${empty(colData.monthData.get(month) ) ? 0 : colData.monthData.get(month)}
总结

以上为我使用过程中,几个较常用的操作。

作者:HadryChen https://blog.csdn.net/baidu_14958441/article/details/128528237

公众号“Java精选”所发表内容注明来源的,版权归原出处所有(无法查证版权的或者未注明出处的均来自网络,系转载,转载的目的在于传递更多信息,版权属于原作者。如有侵权,请联系,笔者会第一时间删除处理!

最近有很多人问,有没有读者交流群!加入方式很简单,公众号Java精选,回复“加群”,即可入群!

(微信小程序):3000+道面试题,包含Java基础、并发、JVM、线程、MQ系列、Redis、Spring系列、Elasticsearch、Docker、K8s、Flink、Spark、架构设计等,在线随时刷题!

特别推荐:专注分享最前沿的技术与资讯,为弯道超车做好准备及各种开源项目与高效率软件的公众号,「大咖笔记」,专注挖掘好东西,非常值得大家关注。点击下方公众号卡片关注

文章有帮助的话,点在看,转发吧!