Excel文件导出

                                          Excel文件导出


import java.io.IOException;
import java.io.InputStream;
import java.net.URLEncoder;

import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.log4j.Logger;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.core.io.ClassPathResource;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import com.thoughtworks.xstream.core.util.Base64Encoder;

/**  
 * @Title  TestController.java   
 * @Package cn.com.headfree.file.controller   
 * @Description excel文件导出 
 * @date  2019年12月19日 下午4:38:32   
 */
public class TestController {
	private static final Logger LOG = Logger.getLogger(TestController.class);
	
	/**
	 * 导出excel数据模板 
	 * @param req
	 * @param resp
	 * */
	@SuppressWarnings("resource")
	@RequestMapping("/excelExport")
	@ResponseBody
	public void excelExport(HttpServletRequest req,HttpServletResponse resp) {
		InputStream fis = null;
		ServletOutputStream out = null;
		try {
			ClassPathResource classPathResource = new ClassPathResource("file/template.xls");
            fis = classPathResource.getInputStream();
            
            //xls格式
			HSSFWorkbook workbook = new HSSFWorkbook(fis);
			//xlsx格式
			//XSSFWorkbook workbook = new XSSFWorkbook(fis);
			
            resp.setContentType("application/force-download;charset=utf-8");
            String fileName = "数据模板表";
            
            //解决导出文件名中文乱码问题
            // 获得请求头中的User-Agent
    		String agent = req.getHeader("User-Agent");
    		// 根据不同的客户端进行不同的编码
    		if (agent.contains("MSIE")) {// IE浏览器
    			fileName = URLEncoder.encode(fileName, "utf-8");
    		} else if (agent.contains("Firefox")) {// 火狐浏览器
    			Base64Encoder base64Encoder = new Base64Encoder();
    			fileName = "=?utf-8?B?" + base64Encoder.encode(fileName.getBytes("utf-8")) + "?=";
    		} else {// 其它浏览器
    			fileName = URLEncoder.encode(fileName, "utf-8");
    		}
            resp.setHeader("Content-disposition", "attachment; filename="+fileName+".xls");
            
            out = resp.getOutputStream();
            workbook.write(out);
        } catch (Exception e) {
            LOG.error("导出excel数据模板失败 ", e);
        } finally {
            //关闭文件输出流
        	try {
				out.flush();
				out.close();
				fis.close();
			} catch (IOException e) {
				LOG.error("导出excel数据模板失败-关闭文件流失败 ", e);
			}
        }			
	}
	
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EasyExcel是一个基于Java的简单易用的Excel文件读写工具,它可以很方便地实现Excel文件导入和导出。下面介绍一下如何使用EasyExcel实现Excel文件导出。 1. 引入EasyExcel依赖 将以下依赖添加到项目的pom.xml文件中: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.7</version> </dependency> ``` 2. 创建Excel实体类 首先,需要创建一个Java类来表示Excel文件的数据结构。例如,如果要导出一个包含学生信息的Excel文件,可以创建一个名为Student的类,并在其中定义需要导出的属性: ```java public class Student { private String name; private Integer age; private String gender; private String address; // 省略getter和setter方法 } ``` 3. 创建Excel文件 在进行Excel文件导出之前,需要先创建一个Excel文件。EasyExcel提供了一个名为ExcelWriter的类,可以用来创建Excel文件。以下是一个创建Excel文件的示例代码: ```java // 创建ExcelWriter对象 ExcelWriter excelWriter = new ExcelWriter(new FileOutputStream("students.xlsx"), ExcelTypeEnum.XLSX); // 创建Sheet对象 Sheet sheet = new Sheet(1, 0, Student.class); // 设置Sheet名称 sheet.setSheetName("学生信息"); // 写入数据 List<Student> data = new ArrayList<>(); // 添加数据到List中 // ... excelWriter.write(data, sheet); // 关闭ExcelWriter对象 excelWriter.finish(); ``` 以上代码中,创建了一个名为“学生信息”的Sheet对象,并设置其数据类型为Student类。然后,将需要导出的数据写入到Excel文件中。 4. 导出Excel文件 创建Excel文件后,就可以通过EasyExcel将其导出了。以下是一个导出Excel文件的示例代码: ```java // 设置响应头信息 response.setContentType("application/vnd.ms-excel"); response.setCharacterEncoding("utf-8"); response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("students.xlsx", "UTF-8")); // 创建ExcelWriter对象 ExcelWriter excelWriter = new ExcelWriter(response.getOutputStream(), ExcelTypeEnum.XLSX, true); // 创建Sheet对象 Sheet sheet = new Sheet(1, 0, Student.class); // 设置Sheet名称 sheet.setSheetName("学生信息"); // 写入数据 List<Student> data = new ArrayList<>(); // 添加数据到List中 // ... excelWriter.write(data, sheet); // 关闭ExcelWriter对象 excelWriter.finish(); ``` 以上代码中,设置了响应头信息,告诉浏览器需要下载一个Excel文件。然后,创建了一个ExcelWriter对象,并将其输出流设置为响应流,这样Excel文件就可以直接输出到浏览器中。最后,将需要导出的数据写入到Excel文件中,并关闭ExcelWriter对象。 通过以上步骤,就可以使用EasyExcel实现Excel文件导出了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值