运用jxls实现excel的导出

2023-11-28 00:20
文章标签 实现 excel 导出 运用 jxls

本文主要是介绍运用jxls实现excel的导出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

运用jxls实现excel的导出

引言:
前两天与一个小姐姐交流学习了导入功能,小姐姐又给我说了一个导出功能,并把她记录的笔记发给我了,通过小姐姐的笔记以及网上查看的一些博客,用jxls简单实现了excel的导出功能,在此向大家分享一下。(小姐姐的笔记记录的很好哟~~)

1、jsxl的介绍

jxls是一个简单的、轻量级的excel导出库,使用特定的标记在excel模板文件中来定义输出格式和布局。java中成熟的excel导出工具有pol、jxl,但他们都是使用java代码的方式来导出excel,编码效率很低且不方便维护。

2、demo

2.1 依赖

<dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.14-beta1</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml-schemas</artifactId><version>3.14-beta1</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.14-beta1</version></dependency><dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpclient</artifactId><version>4.5.2</version></dependency><dependency><groupId>net.sf.jxls</groupId><artifactId>jxls-core</artifactId><version>1.0.6</version></dependency>

2.2 Model

import com.fasterxml.jackson.annotation.JsonFormat;import java.util.Date;public class Employee {private String name;@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")private Date birthDate;private int payment;private double bonus;public Employee(String name, Date birthDate, int payment, double bonus) {this.name = name;this.birthDate = birthDate;this.payment = payment;this.bonus = bonus;}public String getName() {return name;}public void setName(String name) {this.name = name;}public Date getBirthDate() {return birthDate;}public void setBirthDate(Date birthDate) {this.birthDate = birthDate;}public int getPayment() {return payment;}public void setPayment(int payment) {this.payment = payment;}public double getBonus() {return bonus;}public void setBonus(double bonus) {this.bonus = bonus;}
}

2.3 Controller

import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;import com.siit.checkdemo.pojo.Employee;
import org.apache.poi.ss.usermodel.Workbook;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import net.sf.jxls.transformer.XLSTransformer;@Controller
public class FileController {@RequestMapping("/test/downLoad") //请求映射public void toDownload(HttpServletRequest request, HttpServletResponse response) throws ParseException {//调用service层postService接口//List<Post> list = postService.queryAllPost(selectVal,inputVal);List<Employee> list = new ArrayList<>();SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.CHINESE);list.add( new Employee("Elsa", dateFormat.parse("1970-01-10"), 1500, 0.15) );list.add( new Employee("Oleg", dateFormat.parse("1973-12-30"), 2300, 0.25) );list.add( new Employee("Neil", dateFormat.parse("1975-10-05"), 2500, 0.00) );list.add( new Employee("Maria", dateFormat.parse("1978-06-07"), 1700, 0.15) );list.add( new Employee("John", dateFormat.parse("1969-03-30"), 2800, 0.20) );//获取输入流,原始模板位置项目/OA/src/main/resources/template/excelFile.xlsxString templateFileName = getClass().getResource("/templates/excelFile.xlsx").getPath();//假如以中文名下载的话,设置下载文件名称String destFileName = "post.xlsx";//使用map存放查询出来的数据Map<String, Object> map = new HashMap<>();//userList与Excel模板excelFile.xlsx<jx:forEach items="${userList}" var="post">中的userList一致map.put("userList", list);XLSTransformer transformer = new XLSTransformer();InputStream in = null;OutputStream out = null;//设置响应//设置文件下载头response.setHeader("Content-Disposition", "attachment;filename=" + destFileName);//1.设置文件ContentType类型,这样设置,会自动判断下载文件类型response.setContentType("application/vnd.ms-excel");try {in = new BufferedInputStream(new FileInputStream(templateFileName));//生成Excel文件,利用transformXLS来输出文件Workbook workBook = transformer.transformXLS(in, map);//取得输出流out = response.getOutputStream();//将内容写入输出流并把缓存的内容全部发出去workBook.write(out);out.flush();} catch (Exception e) {e.printStackTrace();} finally {if (in != null) {try {in.close();} catch (IOException e) {e.printStackTrace();}}if (out != null) {try {out.close();} catch (IOException e) {e.printStackTrace();}}}}
}

2.4 模板文件

根据自己所需字段,设置模板文件
在这里插入图片描述
jxls使用 Apache JEXL表达式语言来解析定义在excel模板中的表达式。JEXL与JSTL相似,并对JSTL进行了扩展。具体的大家可以百度自己查看。
官网:http://jxls.sourceforge.net/reference/excel_markup.html
eg:

${department.chief.age} //属性可以是无限深度

2.5 测试

运行项目,浏览器输入url请求,回车即可。

在这里插入图片描述

最后,感谢小姐姐的笔记~~

这篇关于运用jxls实现excel的导出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/428733

相关文章

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

Java中Map的五种遍历方式实现与对比

《Java中Map的五种遍历方式实现与对比》其实Map遍历藏着多种玩法,有的优雅简洁,有的性能拉满,今天咱们盘一盘这些进阶偏基础的遍历方式,告别重复又臃肿的代码,感兴趣的小伙伴可以了解下... 目录一、先搞懂:Map遍历的核心目标二、几种遍历方式的对比1. 传统EntrySet遍历(最通用)2. Lambd

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso

SpringBoo WebFlux+MongoDB实现非阻塞API过程

《SpringBooWebFlux+MongoDB实现非阻塞API过程》本文介绍了如何使用SpringBootWebFlux和MongoDB实现非阻塞API,通过响应式编程提高系统的吞吐量和响应性能... 目录一、引言二、响应式编程基础2.1 响应式编程概念2.2 响应式编程的优势2.3 响应式编程相关技术

C#实现将XML数据自动化地写入Excel文件

《C#实现将XML数据自动化地写入Excel文件》在现代企业级应用中,数据处理与报表生成是核心环节,本文将深入探讨如何利用C#和一款优秀的库,将XML数据自动化地写入Excel文件,有需要的小伙伴可以... 目录理解XML数据结构与Excel的对应关系引入高效工具:使用Spire.XLS for .NETC

Nginx更新SSL证书的实现步骤

《Nginx更新SSL证书的实现步骤》本文主要介绍了Nginx更新SSL证书的实现步骤,包括下载新证书、备份旧证书、配置新证书、验证配置及遇到问题时的解决方法,感兴趣的了解一下... 目录1 下载最新的SSL证书文件2 备份旧的SSL证书文件3 配置新证书4 验证配置5 遇到的http://www.cppc

Nginx之https证书配置实现

《Nginx之https证书配置实现》本文主要介绍了Nginx之https证书配置的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起... 目录背景介绍为什么不能部署在 IIS 或 NAT 设备上?具体实现证书获取nginx配置扩展结果验证

C#如何在Excel文档中获取分页信息

《C#如何在Excel文档中获取分页信息》在日常工作中,我们经常需要处理大量的Excel数据,本文将深入探讨如何利用Spire.XLSfor.NET,高效准确地获取Excel文档中的分页信息,包括水平... 目录理解Excel中的分页机制借助 Spire.XLS for .NET 获取分页信息为什么选择 S