--------------------------------------------方式一(新)-----------------------------------------------------------------

这个导出excel是需要excel模板文件,这个方式的好处是可以自定义excel的表头,方式如下:

1.复制该工具类

import net.sf.jxls.exception.ParsePropertyException;
import net.sf.jxls.transformer.XLSTransformer;
import org.apache.poi.hssf.usermodel.HSSFWorkbook; import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;
import java.util.List;
import java.util.Map; public class ExcelTemplateUtils {
/**
*
* @param filename 导出的文件名
* @param dataMap List的集合
* @param model
* @param response
* @throws IOException
*/
@SuppressWarnings("rawtypes")
public void export(String filename, Map<String,List>dataMap, String model, HttpServletResponse response){
XLSTransformer transformer = new XLSTransformer();
HSSFWorkbook workbook;
InputStream in;
try {
//此方法需要类与模板放在同一目录下
in = Thread.currentThread().getContextClassLoader().getResourceAsStream(model);
// in = getClass().getResourceAsStream(model);
workbook = transformer.transformXLS(in, dataMap);
outExcel(workbook, response, filename);
} catch (Exception e) {
e.printStackTrace();
}
} protected void outExcel(HSSFWorkbook workbook, HttpServletResponse response,
String filename) throws UnsupportedEncodingException {
response.setContentType("application ns.ms-excel");
response.setHeader("Expires", "0");
response.setHeader("Cache-Control",
"must-revalidate, post-check=0, pre-check=0");
response.setHeader("Pragma", "public");
response.setHeader("Content-disposition", "attachment;filename="+new String(filename.getBytes("utf-8"),"iso-8859-1")+".xls"); try {
workbook.write(response.getOutputStream());
} catch (ParsePropertyException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}

2.自定义excel模板文件:(不能插入excel文件,所以截图了,如图所示)

3.导出请求代码:

@GetMapping("/export")
public void excelTemplate(String startDate, String endDate, String email, HttpServletResponse response) {
FinancialReq req = new FinancialReq();
req.setEmail(email);
req.setStartDate(startDate);
req.setEndDate(endDate);
List list = adminFinancialService.findExcelList(req);
Map<String, List> beanParams = new HashMap<String, List>();
beanParams.put("financialSummary", list);
ExcelTemplateUtils excel = new ExcelTemplateUtils(); StringBuilder title = new StringBuilder();
title.append("财务统计报表");
title.append(DateUtils.formatDate(new Date(),"yyyyMMddhhmmss"));
excel.export(title.toString(), beanParams, "template_financialSummary.xls", response);
}

--------------------------------------------方式二(旧)----------------------------------------------------------------

导入架包:

gradle(

"org.apache.poi:poi-ooxml:3.16",

下面给出一个Excel导入导出的工具类:

package com.glory.venus.common.utils;

import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List; import org.apache.poi.EncryptedDocumentException;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.DateUtil;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;
import org.apache.poi.xssf.usermodel.XSSFWorkbook; /**
* @author me
* @date 2017-06-08 16:29:25
*/
public class ExcelUtil { /**
* 生成2007及以后版本
* @param list 数据集合
* @param title 表头 表头名称的顺序要与list里的object属性的顺序对应
* @param sheetName sheet名称
* @return
*/
public static Workbook getXSSFWorkbook(List<Object> list,String[] title,String sheetName){
Workbook wb = new XSSFWorkbook();//2007及以后版本 .xslx
return createExcel(wb,list,title,sheetName,0,0);
} /**
* 2003及以前的版本
* @param list 数据集合
* @param title 表头 表头名称的顺序要与list里的object属性的顺序对应
* @param sheetName sheet名称
* @return
*/
public static Workbook getHSSFWorkbook(List<Object> list,String[] title,String sheetName){
Workbook wb = new HSSFWorkbook();//2003及以前的版本 .xsl
return createExcel(wb,list,title,sheetName,0,0);
} /**
* 生成Excel文件
* @param list 数据集合
* @param title 表头
* @param sheetName sheet名称
* @param rowNum 从第几行开始写入
* @param colNum 从第几列开始写入
* @return
*/
private static Workbook createExcel(Workbook wb,List list,String[] title,String sheetName,int rowNum,int colNum) {
if(sheetName == null || "".equals(sheetName)){
sheetName = "sheet1";
}
Sheet sheet = wb.createSheet(sheetName);
Row topRow = sheet.createRow(rowNum);
for (int i = 0; i < title.length; i++) {
sheet.autoSizeColumn(i,true);
topRow.createCell(i+colNum).setCellValue(title[i]);
}
if(list == null || list.size() == 0){
return wb;
}
Object[] objs = null;
for (int i = 0; i < list.size(); i++) {
rowNum++;
Row row = sheet.createRow(rowNum);
objs = getFieldValues(list.get(i));
for (int j = 0; j < objs.length; j++) {
String value = objs[j] == null ? "" : objs[j].toString();
row.createCell(j+colNum).setCellValue(value);
}
}
return wb;
} /**
* 获取对象属性的值
* @param o
* @return
*/
private static Object[] getFieldValues(Object o) {
Object[] value = null;
try {
Field[] fields = o.getClass().getDeclaredFields();
value = new Object[fields.length];
for (int i = 0; i < fields.length; i++) {
String firstLetter = fields[i].getName().substring(0, 1).toUpperCase();
String getter = "get" + firstLetter + fields[i].getName().substring(1);
Method method = o.getClass().getMethod(getter, new Class[] {});
value[i] = method.invoke(o, new Object[] {});
}
} catch (SecurityException e) {
e.printStackTrace();
} catch (NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
} return value;
} /**
* 获取对象属性名称
* @param o
* @return
*/
private static String[] getFieldValue(Object o) {
Field[] fields = o.getClass().getDeclaredFields();
String[] value = new String[fields.length];
for (int i = 0; i < fields.length; i++) {
value[i] = fields[i].getName();
}
return value;
} /**
* 读取Excel
* @param is Excel的文件流
* @return
*/
public static ExcelCellBean readExcel(InputStream is){
Workbook workbook = null;
Sheet sheet = null;
try {
workbook = WorkbookFactory.create(is);
sheet = workbook.getSheetAt(0); //读取第几个工作表sheet
int rowNum = sheet.getLastRowNum();//有多少列
ExcelCellBean eb = new ExcelCellBean();
String[] title = new String[0];
String[] value = new String[0];
List<String[]> values = new ArrayList<String[]>();
int c = 0;//用去区分表头和数值
int colNum = 0;//总共有多少列
int firstCellNum = 0;//第几列开始读取
for(int k = 0;k <= rowNum;k++){
Row row = sheet.getRow(k);//从第几行开始读
if(row == null){//过滤空行
continue;
}
if(c == 0){
firstCellNum = row.getFirstCellNum();
colNum = row.getLastCellNum() - row.getFirstCellNum();
title = new String[colNum];
}else{
value = new String[colNum];
}
int count = 0;//计算放进数值里面的顺序
for (int i = firstCellNum; i < colNum+firstCellNum; i++) {
if(c == 0){
title[count] = getCellFormatValue(row.getCell(i));
}else{
value[count] = getCellFormatValue(row.getCell(i));
}
count++;
}
if(c > 0){
values.add(value);
}
c++;
}
eb.setTitle(title);
eb.setValues(values);
return eb;
} catch (IOException e) {
e.printStackTrace();
} catch (EncryptedDocumentException e) {
e.printStackTrace();
} catch (InvalidFormatException e) {
e.printStackTrace();
}
return null;
} /**
* 从cell获取值
* @param cell
* @return
*/
private static String getCellFormatValue(Cell cell) {
String cellvalue = "";
if(cell != null){
switch (cell.getCellTypeEnum()) {
case NUMERIC:
if(DateUtil.isCellDateFormatted(cell)){//日期类型
cellvalue = cell.getDateCellValue() + "";
}else{
cellvalue = String.valueOf(cell.getNumericCellValue());
}
break;
case BOOLEAN:
cellvalue = cell.getBooleanCellValue() + "";
break;
case FORMULA:
cellvalue = "公式";
break;
case ERROR:
cellvalue = cell.getErrorCellValue() + "";
break;
// case BLANK://空白
// case STRING:
default:
cellvalue = cell.getStringCellValue();
break;
}
}
return cellvalue;
} }

备注;设计到文件的上传,需要的jar:

gradle(
"commons-fileupload:commons-fileupload:1.3.1",""
)
另外 还需要配置一个bean :不然强转 request为MultipertRequest的时候 会出错
@Bean(name = "multipartResolver")
public CommonsMultipartResolver commonsMultipartResolver() {
logger.info("CommonsMultipartResolver");
return new CommonsMultipartResolver();
}

后台 导入、导出Excel 请求 可参考一下代码:

 @RequestMapping(value = "/sport/export", method = RequestMethod.GET)
public void sportExport(HttpServletResponse response) throws IOException {
String[] titles = new String[]{"模板编码", "运动名称", "运动类型", "运动时间", "运动频率", "运动周期", "运动强度", "创建时间", "创建人"};
String sheetName = "运动模板";
List list = service.findAllTemplateSportExcel();
Workbook workbook = ExcelUtil.getXSSFWorkbook(list, titles, sheetName);
OutputStream output = response.getOutputStream();
response.reset();
response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-disposition", "attachment;filename=" + java.net.URLEncoder.encode(sheetName + ".xls", "UTF-8"));
workbook.write(output);
output.close();
} @RequestMapping(value = "/sport/import", method = RequestMethod.POST)
public ResponseBean sportImport(HttpServletRequest request) throws IOException {
MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest)request;
Long creator=1l;//// TODO: 2017-06-27 获取管理员ID
Iterator<String> iterator = multipartRequest.getFileNames();
while(iterator.hasNext()){
MultipartFile multipartFile = multipartRequest.getFile(iterator.next());
if(multipartFile != null){
ExcelCellBean bean=ExcelUtil.readExcel(multipartFile.getInputStream());
return service.importTemplateSport(creator,bean);
}
}
return new ResponseBean(-1,"获取上传文件失败");
}

JAVA Excel导入导出的更多相关文章

  1. Java Excel 导入导出(一)

    本文主要描述通过java实现Excel导入导出 一.读写Excel三种常用方式 1.JXL——Java Excel开放源码项目:读取,创建,更新 2.POI——Apache POI ,提供API给Ja ...

  2. Java Excel导入导出(实战)

    一.批量导入(将excel文件转成list) 1. 前台代码逻辑 1)首先在html页面加入下面的代码(可以忽略界面的样式) <label for="uploadFile" ...

  3. java Excel导入导出工具类

    本文章,导入导出依赖提前定义好的模板 package com.shareworx.yjwy.utils; import java.io.File; import java.io.FileInputSt ...

  4. Java Excel 导入导出(二)

    本文主要叙述定制导入模板——利用XML解析技术,确定模板样式. 1.确定模板列 2.定义标题(合并单元格) 3.定义列名 4.定义数据区域单元格样式 引入jar包: 一.预期格式类型 二.XML模板格 ...

  5. Java——excel导入导出demo

    1. java导入 package xx; import org.apache.poi.hssf.usermodel.HSSFCell;import org.apache.poi.hssf.userm ...

  6. java简易excel导入导出工具(封装POI)

    Octopus 如何导入excel 如何导出excel github项目地址 Octopus Octopus 是一个简单的java excel导入导出工具. 如何导入excel 下面是一个excel文 ...

  7. Java 使用 Jxl 实现 Excel 导入导出

    开发过程中经常需要用到数据的导入导出功能,之前用的是POI,这次使用JXL,JXL相对于POI来说要轻量简洁许多,在数据量不大的情况下还是非常实用的.这里做一下使用JXL的学习记录.首先需要导入相应的 ...

  8. java jxl excel 导入导出的 总结(建立超链接,以及目录sheet的索引)

    最近项目要一个批量导出功能,而且要生成一个单独的sheet页,最后后面所有sheet的索引,并且可以点击进入连接.网上搜索了一下,找到一个方法,同时把相关的excel导入导出操作记录一下!以便以后使用 ...

  9. JAVA实现Excel导入/导出【转】

    JAVA实现Excel导入/导出[转] POI的下载与安装 请到网站http://www.apache.org/dyn/closer.cgi/poi/右击超链接2.5.1.zip下载压缩包poi-bi ...

随机推荐

  1. 用js判断页面是否加载完成

    这可以通过用document.onreadystatechange的方法来监听状态改变, 然后用document.readyState == “complete”判断是否加载完成. 可以采用2个div ...

  2. Android开发:《Gradle Recipes for Android》阅读笔记(翻译)2.4——更新新版本的Gradle

    问题: 你需要更新应用的Gradle版本. 解决方案: 生成一个新的wrapper,或者直接修改属性文件(.properties). 讨论: Android Studio包含了一个Gradle的分发. ...

  3. 浅谈Spring框架注解的用法分析

    原文出处: locality 1.@Component是Spring定义的一个通用注解,可以注解任何bean. 2.@Scope定义bean的作用域,其默认作用域是”singleton”,除此之外还有 ...

  4. CAS 源码编译

    准备 :gradle   idea 第一次用Idea 还是有点不熟悉呀,还是eclipse 顺手! 哈哈 下载源码  :我的是4.2.7 解压 导入idea 重点: 调试时候在写 .没时间

  5. redis集群报错,(error) MOVED 15495 127.0.0.1:7003

        节点会对命令请求进行分析和key的slot计算,并且会查找这个命令所要处理的键所在的槽.如果要查找的哈希槽正好就由接收到命令的节点负责处理, 那么节点就直接执行这个命令. 另一方面, 如果所查 ...

  6. 普通java工程的resources目录寻址

    问题: 普通java工程的src/main/resources目录下的配置文件如何寻址 在src/main/java目录下的代码中如何访问src/main/resources目录下的配置文件? Mav ...

  7. FW 配置一个私有的Docker仓库

    思维 66 3月1日 发布 建分支 0 分支 收藏 0 收藏 我们在本地开发时,如果内网能部署一台Docker服务器,无疑会极大的方便镜像的分享发布,有些私有镜像就是可以直接放到内网服务器上,省去了不 ...

  8. django实现密码加密的注册(数据对象插入)

    在 django实现密码非加密的注册(数据对象插入)的基础上,我们对视图和注册页面进行了简单修改 视图 from django.shortcuts import render,redirect,ren ...

  9. Linux中的特殊字符

    单引号: 在单引号中所有的特殊字符都没有特殊含义 双引号: 在双引号中 $ ` \ 三个字符表示,调用变量的值.引用命令.转义,其他特殊字符均没有特殊含义 反引号: 用反引号括起来的内容被当作系统命令 ...

  10. (4.5)DBCC的概念与用法(DBCC TRACEON、DBCC IND、DBCC PAGE)

    转自:http://www.cnblogs.com/huangxincheng/p/4249248.html DBCC的概念与用法 一:DBCC 1:什么是DBCC 我不是教学老师,我也说不到没有任何 ...