一、批量导出:

/**
*
* @Title: expExcel
* @Description: 批量导出客户信息
* @param @param params
* @param @param request
* @param @param response
* @param @throws Exception
* @return void
* @throws
*/
@RequestMapping("expExcel")
public void expExcel(QueryCustomParam params,HttpServletRequest request,HttpServletResponse response) throws Exception{ User u = getUser(request.getSession());//SessionUtils.getUser(request.getSession()); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd hh:mm"); //获取网站部署路径(通过ServletContext对象),用于确定下载文件位置,从而实现下载
String path = request.getServletContext().getRealPath("/"); List<CustomResp> list = null;
List<ContactsResp> list2 = null;
String fileName = "我的客户导出";
String url = path + "download\\" + fileName + ".xls"; params.setEmpIds(String.valueOf(u.getEmpId()));
QueryContactsParam params2 = new QueryContactsParam();
params2.setEmpId(Long.valueOf(u.getEmpId()));
params2.setCorpId(Long.valueOf(u.getCorpId()));
params2.setFlag("4"); try { list = customService.selectMyCustom(params); //我的客户
list2 = contactsService.selectContactsList(params2); //查询我的客户包含的所有联系人信息 //数据
List<String[]> dataset = new ArrayList<String[]>();
for (int i = 0; i < list.size(); i++) {
String[] arr = new String[16];
arr[0] = list.get(i).getName()==null ? "" : list.get(i).getName().toString();
arr[1] = list.get(i).getShortName()==null ? "" : list.get(i).getShortName().toString();
arr[2] = list.get(i).getNumber()==null ? "" : list.get(i).getNumber().toString();
arr[3] = list.get(i).getAddress()==null ? "" : list.get(i).getAddress().toString();
arr[4] = list.get(i).getUrl()==null ? "" : list.get(i).getUrl().toString();
arr[5] = list.get(i).getDescription()==null ? "" : list.get(i).getDescription().toString();
arr[6] = list.get(i).getHighseasName()==null ? "" : list.get(i).getHighseasName().toString();
arr[7] = list.get(i).getHighseasDate()==null ? "" : sdf2.format(list.get(i).getHighseasDate());
arr[8] = list.get(i).getEmpName()==null ? "" : list.get(i).getEmpName().toString();
arr[9] = list.get(i).getOrganName()==null ? "" : list.get(i).getOrganName().toString();
arr[10] = ""; //领取日期 暂无数据
arr[11] = list.get(i).getExpireDate()==null ? "" : sdf2.format(list.get(i).getExpireDate());
arr[12] = "4"; //联系人数量
arr[13] = list.get(i).getCreateDate()==null ? "" : sdf2.format(list.get(i).getCreateDate());
arr[14] = list.get(i).getCustomStatusName()==null ? "" : list.get(i).getCustomStatusName().toString();
arr[15] = list.get(i).getCustomLevelName()==null ? "" : list.get(i).getCustomLevelName().toString(); dataset.add(arr);
} //数据
List<String[]> dataset2 = new ArrayList<String[]>();
for (int i = 0; i < list2.size(); i++) {
String[] arr2 = new String[16];
arr2[0] = list2.get(i).getName()==null ? "" : list2.get(i).getName().toString();
arr2[1] = list2.get(i).getSex()==null ? "" : getSex(list2.get(i).getSex());
arr2[2] = list2.get(i).getBirthday()==null ? "" : sdf.format(list2.get(i).getBirthday());
arr2[3] = "";
arr2[4] = list2.get(i).getOrganName()==null ? "" : list2.get(i).getOrganName().toString();
arr2[5] = list2.get(i).getPosition()==null ? "" : list2.get(i).getPosition().toString();
arr2[6] = list2.get(i).getCompany()==null ? "" : list2.get(i).getCompany().toString();
arr2[7] = list2.get(i).getAddress()==null ? "" : list2.get(i).getAddress().toString();
arr2[8] = list2.get(i).getUrl()==null ? "" : list2.get(i).getUrl().toString();
arr2[9] = list2.get(i).getInterest()==null ? "" : list2.get(i).getInterest().toString();
arr2[10] = list2.get(i).getRemark()==null ? "" : list2.get(i).getRemark().toString();
arr2[11] = list2.get(i).getCreateDate()==null ? "" : sdf2.format(list2.get(i).getCreateDate());
arr2[12] = list2.get(i).getCustomName()==null? "" : list2.get(i).getCustomName();
arr2[13] = list2.get(i).getEmpName()==null? "" : list2.get(i).getEmpName();
arr2[14] = list2.get(i).getContactsRoleName()==null? "" : list2.get(i).getContactsRoleName();
arr2[15] = list2.get(i).getContactsRelationName()==null? "" : list2.get(i).getContactsRelationName(); dataset2.add(arr2);
} //表头
String[] handers1 = {"客户全称","客户简称","客户编号","地址","网址","介绍","公海名称","加入公海时间","跟进人","跟进人部门","领取日期","到期日期","联系人数量","创建日期","客户状态","客户分级" };
String[] handers2 = {"姓名","性别","生日","手机","部门","职务","公司","公司地址","公司网站","兴趣爱好","备注","创建日期","客户简称","归属人","角色关系","亲密程度" }; //对象
ExcelExp e1 = new ExcelExp("我的客户", handers1, dataset);
ExcelExp e2 = new ExcelExp("客户联系人", handers2, dataset2); List<ExcelExp> mysheet = new ArrayList<ExcelExp>();
mysheet.add(e1);
mysheet.add(e2); ExcelExportUtil.exportManySheetExcel(url, mysheet); //生成sheet
ExcelExportUtil.getExcel(url, fileName, response); //下载sheet } catch (IOException e) {
e.printStackTrace();
}
}

Excel对象:

public class ExcelExp {

    private String fileName;// sheet的名称
private String[] handers;// sheet里的标题
private List<String[]> dataset;// sheet里的数据集 public ExcelExp(String fileName, String[] handers, List<String[]> dataset) {
this.fileName = fileName;
this.handers = handers;
this.dataset = dataset;
} //getter、setter方法 }

生成Excel:

/**
*
* @Title: exportManySheetExcel
* @Description: 可生成单个、多个sheet
* @param @param file 导出文件路径
* @param @param mysheets
* @return void
* @throws
*/
public static void exportManySheetExcel(String file, List<ExcelExp> mysheets){ HSSFWorkbook wb = new HSSFWorkbook();//创建工作薄
List<ExcelExp> sheets = mysheets; //表头样式
HSSFCellStyle style = wb.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式
//字体样式
HSSFFont fontStyle = wb.createFont();
fontStyle.setFontName("微软雅黑");
fontStyle.setFontHeightInPoints((short)12);
fontStyle.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
style.setFont(fontStyle); for(ExcelExp excel: sheets){
//新建一个sheet
HSSFSheet sheet = wb.createSheet(excel.getFileName());//获取该sheet名称 String[] handers = excel.getHanders();//获取sheet的标题名
HSSFRow rowFirst = sheet.createRow(0);//第一个sheet的第一行为标题
//写标题
for(int i=0;i<handers.length;i++){
//获取第一行的每个单元格
HSSFCell cell = rowFirst.createCell(i);
//往单元格里写数据
cell.setCellValue(handers[i]);
cell.setCellStyle(style); //加样式
sheet.setColumnWidth(i, 4000); //设置每列的列宽
} //写数据集
List<String[]> dataset = excel.getDataset();
for(int i=0;i<dataset.size();i++){
String[] data = dataset.get(i);//获取该对象 //创建数据行
HSSFRow row = sheet.createRow(i+1); for(int j=0;j<data.length;j++){
//设置对应单元格的值
row.createCell(j).setCellValue(data[j]);
}
}
} // 写文件
try { FileOutputStream out = new FileOutputStream(new File(file));
out.flush();
wb.write(out);
out.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}

JAVA导出Excel(支持多sheet)的更多相关文章

  1. [转载]Java导出Excel

    一.需求介绍 当前B/S模式已成为应用开发的主流,而在开发企业办公系统的过程中,常常有客户这样子要求:把系统数据库中的数据导出到Excel,用户查看报表时直接用Excel打开.或者是:用户已经习惯用E ...

  2. java导出excel表格

    java导出excel表格: 1.导入jar包 <dependency> <groupId>org.apache.poi</groupId> <artifac ...

  3. java导出excel报表

    1.java导出excel报表: package cn.jcenterhome.util; import java.io.OutputStream;import java.util.List;impo ...

  4. Java导出Excel和CSV(简单Demo)

    Java导出Excel和CSV的简单实现,分别使用POI和JavaCSV. JavaBean public class ReportInfo { int id; String date; int nu ...

  5. Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类

    Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类 ============================== ©Copyright 蕃薯耀 20 ...

  6. java导出excel模板数据

    Java导出excel数据模板,这里直接贴代码开发,流程性的走下去就是步骤: String[] colName=new String[]{"期间","科目代码" ...

  7. java导出excel工具类

    java导出excel须要使用HSSFWorkbook这个类,须要导入poi-3.6-20091214.jar 工具类调用例如以下: package com.qlwb.business.util; i ...

  8. 使用JAVA导出EXCEL表格(POI)

    一.POI概述 Jakarta POI 是一套用于访问微软格式文档的Java API.POI提供API给Java程序对Microsoft Office格式档案读和写的功能.在许多企业办公系统中,经常会 ...

  9. java导出excel报错:getOutputStream() has already been called for this response

    对于java导出excel报错的问题,查了很多都说是在使用完输出流以后调用以下两行代码即可 out.clear(); out = pageContext.pushBody(); 但这也许是页面上输出时 ...

  10. CRM 报表导出excel时指定sheet名

    如图所示,设置PageName即可: 这样导出excel时,sheet的名就有了:

随机推荐

  1. 使用Idea工具创建Maven WebApp项目

    (1)New Project,选择模板,配置SDK (2)配置项目名及项目组名 GroupID是项目组织唯一的标识符, 比如我的项目叫test001 那么GroupID应该是 com.lixiaomi ...

  2. USACO 1.3.4 Prime Cryptarithm 牛式(模拟枚举)

    Description 下面是一个乘法竖式,如果用我们给定的那n个数字来取代*,可以使式子成立的话,我们就叫这个式子牛式. * * * x * * ------- * * * * * * ------ ...

  3. scrum立会报告+燃尽图(第三周第六次)

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2286 项目地址:https://coding.net/u/wuyy694 ...

  4. 20181023-4 Beta阶段第1周/共2周 Scrum立会报告+燃尽图 01

    作业要求:[https://edu.cnblogs.com/campus/nenu/2018fall/homework/2383] 版本控制:[https://git.coding.net/lglr2 ...

  5. lintcode-457-经典二分查找问题

    457-经典二分查找问题 在一个排序数组中找一个数,返回该数出现的任意位置,如果不存在,返回-1 样例 给出数组 [1, 2, 2, 4, 5, 5]. 对于 target = 2, 返回 1 或者 ...

  6. Docker 安装与常用命令介绍

    docker的镜像文件作用就是:提供container运行的文件系统层级关系(基于AUFS实现),所依赖的库文件.已经配置文件等等. 安装docker yum install -y docker 启动 ...

  7. 结对项目之对PIE的测试程序

    项目要求: 构造程序,分别是: 不能触发Fault. 触发Fault,但是不能触发Error. 触发Error,但是不能产生Failure. 结对对象:陈秋月  学号:2013110404  博客地址 ...

  8. 2nd scrum站立会议

    scrum站立会议 站立会议是让团队成员每日面对面站立互相交流他们所承担任务的进度.它的一个附带好处是让同组成员了解到工作的情况.本质上是为了团队交流,不是会议报告. 站立会议的目的: 1.让整个团队 ...

  9. Spring 学习 5- task 定时任务

    Spring-Task 1.这是网上的: 后面是我自己的配置 Spring3.0以后自主开发的定时任务工具,spring task,可以将它比作一个轻量级的Quartz,而且使用起来很简单,除spri ...

  10. asp.net 中使用 pagedlist 分页并具有查询功能的实现方法

    用pagedlist在项目中做分页已N次了,今天再次用实例来实现一个带查询功能的分页例子. 1.在view代码: @using PagedList.Mvc@model BGZS.Models.User ...