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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • gg修改器修改数值没有用怎么办_gg修改器怎么用怎么修改数值 修改数值方法介绍…[通俗易懂]

    gg修改器修改数值没有用怎么办_gg修改器怎么用怎么修改数值 修改数值方法介绍…[通俗易懂]gg修改器怎么用怎么修改数值修改数值方法介绍GG修改器-全称GameGuardian是非常好用的手机修改器,但它需要ROOT权限,而现在要想ROOT一台手机难度是很大的,因此,本文介绍最新的GG修改免ROOT框架使用方法。现在市面上很多多开框架都支持ROOT,但支持最新安卓Q或者安卓11的却很少,并且运行GG修改器时会经常报错。并且,很多用户发现GG修改器也很难下载。X8沙箱,据说拥有完整系统级别…

    2025年9月13日
    4
  • Chrome浏览器打印flash log

    Chrome浏览器是自带的Flash插件,因此系统默认位置的mm.cfg会失效,无法打印出log。

    2022年4月14日
    37
  • OpenCV学习笔记:resize函数改变图像的大小

    OpenCV提供了resize函数来改变图像的大小,函数原型如下:void resize(InputArray src,OutputArray dst,Size dsize,double fx=0,double fy=0,int interpolation=INTER_LINEAR );先解释一下各个参数的意思:src:输入,原图像,即待改变大小的图像

    2022年4月8日
    183
  • ES6基础之——继承extends

    ES6基础之——继承extends一个类可以去继承其他类里面的东西,这里定义一个叫Person的类,然后在constructor里面添加两个参数:name和birthday;下面再添加一个自定义的方法intro,这个方法就是简单地返

    2022年7月1日
    24
  • Java继承

    Java继承一:继承的概述1.继承的定义继承:就是子类继承父类的属性和行为,使得子类对象具有与父类相同的属性、相同的行为。子类可以直接访问父类中的非私有的属性和行为。–注:父类又称为超类或者基类。子类又称为派生类!2.继承的格式通过 extends 关键字,可以声明一个子类继承另外一个父类,定义格式如下:class父类{…}class子类extends父类{…}二、关于继承之后的成员变量1.当成员变量不重名如果子类父类中出现不重名的成员变量,这时的访问是没有影

    2022年7月7日
    19
  • idea202.3.3激活码[在线序列号]

    idea202.3.3激活码[在线序列号],https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月19日
    460

发表回复

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

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