Java导出Excel文件的两种方法
将数据以Excel表格的形式导出:
首先下载poi的jar包,导入项目中,或者使用maven仓库管理,在pom文件添加:
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.9</version>
</dependency>
前端代码:
页面上定义下载/导出按钮,点击按钮时下载/导出,如:
<button class="" id="exportDate" onclick="exportDate()">下载/导出</button>
function exportDate(){
var url=""; //路径
window.open(url);
}
后端代码:
Controller层:
@RequestMapping(value="/exportDate",method=RequestMethod.GET)
public void exportDate(需要接受的参数/条件,HttpServletResponse response) throws Exception{
//如涉及权限/级别/条件等,先进行判断;
//根据条件等查询要导出的数据
List<Object> list = 查询要导出的数据;
//可先判断要导出的数据的数量来确定使用HSSFWorkbook工具类或者SXSSFWorkbook工具类
if(list.size()>60000){
list = list.subList(0,60000);
}
//将数据放入HSSFWorkbook对象中
HSSFWorkbook wb = xxxService.getWb(list);
//大数据量时使用SXSSFWorkbook工具类
//SXSSFWorkbook wb = xxxService.getWb(list);
//定义导出的表名
String fileName = URLEncoder.encode("表名"+".xls","UTF-8");
ByteArrayOutputStream os = new ByteArrayOutputStream();
wb.write(os);
if(os.size() > 0){
response.setContentType("application/octet-stream");
response.addHeader("Content-Disposition","attachment;filename="+fileName);
response.addHeader("Content-Length",""+os.size());
IOUtils.write(os.toByteArray(),response.getOutputStream());
response.getOutputStream().flush();
}
os.close();
}
获取HSSFWorkbook/SXSSFWorkbook工具类对象的方法,可写在service层
一、HSSFWorkbook工具类(导出.xls格式文件)
HSSFWorkbook对象,最多支持65535行,适用一般数据量少导出
//适用公共方法获取表单元格标题
public HSSFWorkbook getWb(List<Object> list) throws Exception{
//创建对象
HSSFWorkbook wb = new HSSFWorkbook();
//创建一个sheet
HSSFSheet sheet = wb.createSheet("sheet名");
//添加表头
HSSFRow row = sheet.createRow((int)0);
//单元格样式
HSSFCellStyle style = wb.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
HSSFCell cell = row.createCell(0);
//创建公共工具类对象
Utils util = new Utils();
//调用方法获得标题
Map<String,String> map = util.getBeanComment("实体类路径");
int i=0;
for (String key : map.keySet()) {
cell = row.createCell(i);
cell.setCellValue(map.get(key));
cell.setCellStyle(style);
i++;
}
i=0;
for (Object obj:list) {
row = sheet.createRow((int) i + 1);
int j=0;
for (String key : map.keySet()) {
cell=row.createCell(j);
cell.setCellValue(BeanUtils.getProperty(obj,key));
j++;
}
i ++ ;
}
return wb;
}
二、SXSSFWorkbook工具类(导出.xlsx格式文件,适用于数据量大的文件导出)
SXSSFWorkbook对象,只支持.xlsx格式。它就是用来解决大数据量以及超大数据量的导入导出操作的,
单个sheet表就支持近104万条数据了。要是导出104万以上的数据,这时我们必须拆分到多个工作表来实现。
//以数组的方式手动定义表单元格标题和对应值
public SXSSFWorkbook getWb(String sheetName,String[] title,String[][] values){
//内存中只创建100个临时对象,超过100个将释放不用对象
SXSSFWorkbook wb = new SXSSFWorkbook(100);
//工作表对象
Sheet sheet = null;
//行对象
Row row = null;
//列对象
Cell cell = null;
int rowNo = 0;
int pageRowNo = 0;
//表单样式风格
CellStyle style = wb.createCellStyle();
style.setAlignment(CellStyle.ALIGN_CENTER);
if(values != null && values.length>0){
for(int j=0;j<values.length;j++){
//超过一百万行后换一个工作薄,单个sheet最多1048576行
if(rowNo%1000000 == 0){
sheet = wb.createSheet("第"+(rowNo/1000000+1)+"个工作薄");
sheet = wb.getSheetAt(rowNo/1000000);
pageRowNo = 0;
}
rowNo++;
//创建标题
if(pageRowNO == 0){
row = sheet.createRow(0);
for(int i=0;i<title.length;i++){
cell = row.createCell(i);
cell.setCellValue(title[i]);
cell.setCellStyle(style);
if(i==title.length-1){
sheet.setDefaultColumnWidth(20);
}
}
}else{
//创建行
row = sheet.createRow(pageRowNo);
for(int k=0;k<values[j].length;k++){
// 创建列
cell = row.createCell(k);
if(k == 0){
//对列进行赋值
cell.setCellValue(Long.parseLong(values[j][k]));
}else{
if(numType(values[j][k])){
cell.setCellValue(Double.parseDouble(values[j][k]));
}else{
cell.setCellValue(String.valueOf(values[j][k]));
}
}
cell.setCellStyle(style);
}
}
pageRowNo++;
}
}
return wb;
}
如果用一中公共工具类的getBeanComment()方法,如下:
public Map<String,String> getBeanComment(String bean){
Map<String,String> map = new HashMap<>();
try{
Class clz = Class.forName(bean);
Field[] strsSub = clz.getDeclaredFields();
Class clzSuper = Class.forName(bean).getSuperclass();
List<Field> strs = new ArrayList<>();
for(Field filed : strsSub){
strs.add(filed);
}
if(null != clzSuper){
Field[] StrsSuper = clzSuper.getDeclaredFields();
for(Field field : StrsSuper){
strs.add(field);
}
}
//StringBuffer sb = new StringBuffer();
for(Field field : strs){
Comment comment = field.getAnnotation(Comment.class);
if(null == comment){
continue;
}
String name = field.getName();
if("id".equals(name)){
continue;
}
if(StringUtils.isNotBlank(comment.value())){
map.put(name, comment.value());
}
}
return map;
}catch(ClassNotFoundException e) {
e.printStackTrace();
return null;
}
}
注:
可参考:https://blog.csdn.net/runzhisheng114/article/details/75303750;
https://blog.csdn.net/u014621859/article/details/54944059;
Java导出Excel文件的两种方法的更多相关文章
- .NET CORE 2.1 导出excel文件的两种方法
最近在做 MVC 项目的时候遇到项目的导出,下面总结下两种导出到excel 的方法 第一种方法: 将文件写到本地,然后返回这个File 或者返回这个 File 的绝对地址 其中 _hostingE ...
- web导出excel文件的几种方法
总的来说,两种方法:服务器端生成和浏览器端生成. 服务器端生成就是:根据用户请求,获取相应的数据,使用poi/jxl, jacob/jawin+excel,或是用数据拼html的table或是cvs纯 ...
- Java读取Excel文件的几种方法
Java读取 Excel 文件的常用开源免费方法有以下几种: 1. JDBC-ODBC Excel Driver 2. jxl.jar 3. jcom.jar 4. poi.jar 简单介绍: 百度文 ...
- [转载]Java操作Excel文件的两种方案
微软在桌面系统上的成功,令我们不得不大量使用它的办公产品,如:Word,Excel.时至今日,它的源代码仍然不公开已封锁了我们的进一步应用和开发.在我们实际开发企业办公系统的过程中,常常有客户这样子要 ...
- mysql导出excel文件的几种方法
方法一 用mysql的命令和shell select * into outfile './bestlovesky.xls' from bestlovesky where 1 order by id d ...
- 读取Excel文件的两种方法
第一种方法:传统方法,采用OleDB读取EXCEL文件, 优点:写法简单,缺点:服务器必须安有此组件才能用,不推荐使用 private DataSet GetConnect_DataSet2(stri ...
- 读取Excel文件的两种方法比较 以及用NPOI写入Excel
1. 采用NPOI方式,只需引用NPOI.dll,但目前最高只能到2.4.0版. 缺点:只支持.xls,不支持.xlsx格式.github上的2.4.1版支持.xlsx,但总提示缺ICSharpCod ...
- Oracle导出DMP文件的两种方法
本文转载自:http://www.cnblogs.com/o-andy-o/archive/2013/06/05/3118611.html 导出: 方法一:利用PL/SQL Developer工具 ...
- java读取excel文件的两种方式
方式一: 借用 package com.ij34.util; /** * @author Admin * @date 创建时间:2017年8月29日 下午2:07:59 * @version 1.0 ...
随机推荐
- mysql查询昨天 一周前 一月前 一年前的数据
mysql 昨天 一周前 一月前 一年前的数据 这里主要用到了DATE_SUB, 参考如下 代码如下: SELECT * FROM yh_contentwhere inputtime>DATE_ ...
- java反射,简单demo
直接上码 //获取方法.属性.构造函数时加 Declared 表示获取本类全部的,不分修饰符:不加 Declared 表示获取从父类继承的和本类公共的 //获取 First 类的无参构造函数 Cons ...
- Linux命令及全称(部分)
man: manual 意思是手册,可以用这个命令查询其他命令的用法. pwd:print working directory 显示当前工作路径. su:swith user 切换用户,切换 ...
- 0728MySQL数据库InnoDB存储引擎重做日志漫游REDOLOG,UNDOLOG
转自http://www.mysqlops.com/2012/04/06/innodb-log1.html 00 – Undo LogUndo Log 是为了实现事务的原子性,在MySQL数据库Inn ...
- Spring MVC-表单(Form)处理示例(转载实践)
以下内容翻译自:https://www.tutorialspoint.com/springmvc/springmvc_form_handling.htm 说明:示例基于Spring MVC 4.1.6 ...
- [Linux]Apache配置虚拟主机
Apache 配置虚拟主机的方式很多,种类也很多,主要分为两类: 基于名称的虚拟主机 (每个 IP 多个站点) 基于 IP 的虚拟主机 (每个 IP 一个站点) 基于名称的虚拟主机: www.2 ...
- hdu1716(库函数next_permutation)
题目意思: 现有四张卡片,用这四张卡片能排列出非常多不同的4位数,要求按从小到大的顺序输出这些4位数. 注意首位没有前导0 pid=1716">http://acm.hdu.edu.c ...
- Sql Server 强制断开数据库已有连接的方法
用管理员账户sa登陆,然后在master下新建查询: 在查询窗体输入: declare @i int declare cur cursor for select spid from sysproces ...
- Chrome改动浏览器User Agent
对浏览器快捷方式右键->改动目标项为 C:\Users\LJ\AppData\Local\Google\Chrome\Application\chrome.exe --user-agent=&q ...
- 刚開始学习的人非常有用:struts2中将jsp数据传到action的几种方式
先给上struts.xml代码: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE strut ...