XLSTransformer 导出Excel数据[通俗易懂]

XLSTransformer 导出Excel数据[通俗易懂]先上代码:packagecn.export.util;importjava.io.FileInputStream;importjava.net.URLEncoder;importjava.util.HashMap;importjava.util.List;importjava.util.Map;importjavax.servlet.ServletOutp

大家好,又见面了,我是你们的朋友全栈君。

先上代码

java code:

<pre name="code" class="java">package cn.export.util;
import java.io.FileInputStream;
import java.net.URLEncoder;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.jxls.transformer.XLSTransformer;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
/**
 * 导出文件util
 * @author
 */
public class ExportUtil {
	@SuppressWarnings("unchecked")
	public static void exportData(HttpServletRequest req, HttpServletResponse resp, List results,String fileName, 
			String year,String quarter, String filePath) throws Exception{
		FileInputStream fis = null;
		ServletOutputStream os = null;
		XLSTransformer transformer = new XLSTransformer();
		Map params = new HashMap();
		params.put("year", year);
		params.put("quarter", quarter);
		params.put("results", results);
		
		fis = new FileInputStream(filePath);
		resp.addHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8") + ".xls");
		resp.setContentType("application/vnd.ms-excel;charset=gbk");
		resp.setHeader("Location", URLEncoder.encode(fileName,"UTF-8") + ".xls");
		
		HSSFWorkbook wb =  transformer.transformXLS(fis, params);
		os = resp.getOutputStream();
		wb.write(os);
		os.flush();
		os.close();
		fis.close();
	}
}

java code:

package cn.export.com;
import java.io.IOException;
import java.net.URL;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import cn.export.util.ExportUtil;
public class ExportServlet extends HttpServlet{
	
	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
		this.doPost(req, resp);
	}
	
	@SuppressWarnings("unchecked")
	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp){
		try {
			String fileName = "服装销售统计";
			List results = new ArrayList();
			for(int i = 0; i < 3; i++){
				Map resMap = new HashMap();
				resMap.put("id", i);
				resMap.put("name", "女装"+i);
				resMap.put("area", "广州");
				resMap.put("traffic", "高铁");
				resMap.put("level", "A");
				resMap.put("time", "2014/09/19");
				resMap.put("operator", "张三");
				resMap.put("remark", "销售良好");
				results.add(i, resMap);
			}
			URL url = this.getClass().getClassLoader().getResource("");
			String filePath = url.getPath() + "doc/fz.xls";
			ExportUtil.exportData(req, resp, results, fileName, "2014", "2", filePath);
		} catch (Exception e) {
		}finally{
			try {
			} catch (Exception e) {
			}
		}
	}
}

所需jar包:

XLSTransformer 导出Excel数据[通俗易懂]

所需jar包下载: 点击这里  (该功能单独测试,没有和其他框架整合)

Excel表模板格式:

XLSTransformer 导出Excel数据[通俗易懂]

(注:excel获取数据的方式: ${results.get(“key”)} ,key为上面代码中map的key)


结果显示:

XLSTransformer 导出Excel数据[通俗易懂]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163870.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【python】蒙特卡洛树搜索(MCTS)简单实现

    过程包括以下四步:选择Selection:从根节点R开始,递归选择最优的子节点(后面会解释)直到达到叶子节点L。扩展Expansion:如果L不是一个终止节点(也就是,不会导致博弈游戏终止)那么就创建一个或者更多的字子节点,选择其中一个C。模拟Simulation:从C开始运行一个模拟的输出,直到博弈游戏结束。反向传播Backpropagation:用模拟的结果输…

    2022年4月4日
    53
  • redis 缓存技术与memcache的最大差别

    redis 缓存技术与memcache的最大差别

    2021年12月5日
    36
  • django的drf框架的优点_道德经的理解与感悟

    django的drf框架的优点_道德经的理解与感悟Django是基于Python编程语言开发的一套重量级的用于web开发的框架所谓web开发框架,就是基于网络通信原理,为了便于开发,对代码流进行了统一的封装和集成Django是对Python的封装,而DRF又在Django的基础上做了进一步的封装相较于Django,DRF更加适用于前后端分离的开发模式Django自带template模板,最终会生成一个html页面。而DRF通过序列化器和丰富的视图类,向服务器提交json格式的数据。…

    2025年8月2日
    3
  • 转录组fpkm是什么意思_fpkm值越大表达量

    转录组fpkm是什么意思_fpkm值越大表达量在转录组测序(RNA-Seq)中,基因的表达量是我们关注的重点。基因表达量的衡量指标有:RPKM、FPKM、TPM。RPKM:ReadsPerKilobaseMillion;说实话,这个英文说

    2022年8月3日
    41
  • 远程开机(外网WOL远程唤醒)「建议收藏」

    远程开机(外网WOL远程唤醒)「建议收藏」Win10开启网络唤醒功能的操作方法:PS:远程唤醒的要求1.首先,我们要在主板BIOS里面设置WOL唤醒功能的开关,大部分主板都会支持唤醒2.电脑的主板和网卡需要支持网络唤醒。一般无线网卡是不支持的,板载的有线网卡一般是可以的。3.所在网络环境需要有公网IP。如果是ADSL拨号的话,如果获取的是私网地址的话,那可以向运营商申请公网IP。4.主机跟路由器要保证一直通电,…

    2022年6月2日
    52
  • 操作系统之进程管理习题[通俗易懂]

    操作系统之进程管理习题[通俗易懂]1.操作系统对进程管理的程序叫进程调度。进程调度就是按照某种算法从就绪队列中选取进程,让该进程获得cpu。多个进程竞争一个CPU,获得CPU的次序是由调度算法决定的。考虑5个进程见下表,1的优先级最高,给出在采用下述几种调度算法下的调度次序(1).非剥夺优先级(2).剥夺优先级(3).时间片轮转(时间片为2) 进程 创建时间 ……

    2025年9月23日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号