这里用的是easypoi

首先引入jar包

<!-- excel -->
<dependency>
<groupId>cn.afterturn</groupId>
<artifactId>easypoi-base</artifactId>
<version>${easypoi.version}</version>
</dependency>
<dependency>
<groupId>cn.afterturn</groupId>
<artifactId>easypoi-web</artifactId>
<version>${easypoi.version}</version>
</dependency>
<dependency>
<groupId>cn.afterturn</groupId>
<artifactId>easypoi-annotation</artifactId>
<version>${easypoi.version}</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.1.1</version>
</dependency>
2.业务代码
(1)service接口层代码
/**
* 获取导出列表
* @param jsonParam
* @return
* @throws Exception
*/
Map<String,Object> getDownloadAllStaffWorkers(JSONObject jsonParam )throws Exception;
(2)serviceImpl实现类代码
红色部分是因为要先把文件上传到服务器,然后后端获取,然后再返给前端一个URL。一般不用谢
@Override
public Map<String, Object> getDownloadAllStaffWorkers(JSONObject jsonParam) throws Exception {
String workerName = jsonParam.getString("workerName");
String workerCardNum = jsonParam.getString("workerCardNum");
String workerPhone = jsonParam.getString("workerPhone");
Long allStaffWorkerTypeId = jsonParam.getLong("allStaffWorkerTypeId");
String workerCode = jsonParam.getString("workerCode");
Long sysId = jsonParam.getLong("sysId");
String clzName = "员工表";
String sessionToken = jsonParam.getString("sessionToken");
/*
查询导出员工列表
*/
Example example = new Example(AllStaffWorkers.class);
Example.Criteria criteria = example.createCriteria();
//是否有效:1.有效 2.无效
criteria.andEqualTo("isEnabled", ConstantsConfig.IS_ENABLED_YES);
//是否删除:1未删除 2.已删除
criteria.andEqualTo("isDeleted",ConstantsConfig.IS_DELETED_NO);
criteria.andEqualTo("sysId",sysId);
if (!Strings.isNullOrEmpty("workerName")){
criteria.andLike("workerName",workerName);
}
if (!Strings.isNullOrEmpty(workerCardNum)){
criteria.andEqualTo("workerCardNum",workerCardNum);
}
if (!Strings.isNullOrEmpty(workerPhone)){
criteria.andEqualTo("workerPhone",workerPhone);
}
if (!Strings.isNullOrEmpty(String.valueOf(allStaffWorkerTypeId))){
criteria.andEqualTo("allStaffWorkerTypeId",allStaffWorkerTypeId);
}
if (!Strings.isNullOrEmpty(workerCode)){
criteria.andEqualTo("workerCode",workerCode);
}
List<AllStaffWorkers> allStaffWorkersList = allStaffWorkersMapper.selectByExample(example);
//导出数据
HSSFWorkbook workbook = new HSSFWorkbook();
//声明一个表格
HSSFSheet sheet = workbook.createSheet("员工信息表");
//设置表格的默认宽度
sheet.setDefaultColumnWidth((short) 30);
//需要导出的文件名字
String fileName = clzName + ".xls";
int rowNum = 1;
//导出Excel 表格头部
String [] headers = {"姓名","手机号","身份证号","性别","部门代码","归属部门","上级部门","人员类型","岗位/工种","状态"};
HSSFRow row = sheet.createRow(0);
//在Excel中添加表头
for (int i = 0;i<headers.length;i++){
HSSFCell cell = row.createCell(i);
HSSFRichTextString text = new HSSFRichTextString(headers[i]);
cell.setCellValue(text);
}
HSSFRow row1 = null;
for (AllStaffWorkers allStaffWorkers : allStaffWorkersList){
String workerSex = null;
if (allStaffWorkers.getWorkerSex() == 1){
workerSex = "男";
}else if (allStaffWorkers.getWorkerSex() ==2){
workerSex ="女";
}else{
workerSex = "";
}
row1 = sheet.createRow(rowNum);
row1.createCell(0).setCellValue(allStaffWorkers.getWorkerName());
row1.createCell(1).setCellValue(allStaffWorkers.getWorkerPhone());
row1.createCell(2).setCellValue(allStaffWorkers.getWorkerCardNum());
row1.createCell(3).setCellValue(workerSex);
//组织管理表
Long allStaffOrgId = allStaffWorkers.getAllStaffOrgId();
AllStaffOrg allStaffOrg = new AllStaffOrg();
allStaffOrg.setAllStaffOrgId(allStaffOrgId);
allStaffOrg.setIsDeleted(ConstantsConfig.IS_DELETED_NO);
allStaffOrg.setIsEnabled(ConstantsConfig.IS_ENABLED_YES);
AllStaffOrg allStaffOrg1 = allStaffOrgMapper.selectOne(allStaffOrg); row1.createCell(4).setCellValue(allStaffOrg1.getOrgCode());
row1.createCell(5).setCellValue(allStaffOrg1.getOrgName());
row1.createCell(6).setCellValue(allStaffOrg1.getParentId());
//工种表
allStaffWorkerTypeId = allStaffWorkers.getAllStaffWorkerTypeId();
if (allStaffWorkerTypeId != null){
AllStaffWorkerType allStaffWorkerType = new AllStaffWorkerType();
allStaffWorkerType.setAllStaffWorkerTypeId(allStaffWorkerTypeId);
allStaffWorkerType.setIsDeleted(ConstantsConfig.IS_DELETED_NO);
allStaffWorkerType.setIsEnabled(ConstantsConfig.IS_ENABLED_YES);
AllStaffWorkerType allStaffWorkerType1 = allStaffWorkerTypeMapper.selectOne(allStaffWorkerType);
row1.createCell(7).setCellValue(allStaffWorkerType1.getWorkerTypeName());
row1.createCell(8).setCellValue(allStaffWorkerType1.getWorkerTypeName());
}else {
continue;
}
//字典表
Long dictId = allStaffWorkers.getDictCommId();
if (dictId != null){
DictComm dictComm = new DictComm();
dictComm.setDictId(dictId);
dictComm.setIsDeleted(ConstantsConfig.IS_DELETED_NO);
dictComm.setIsEnabled(ConstantsConfig.IS_ENABLED_YES);
DictComm dictComm1 = dictCommMapper.selectOne(dictComm);
row1.createCell(9).setCellValue(dictComm1.getDictName());
rowNum++;
}else {
continue;
}
}
/*byte[] fileByte = workbook.getBytes();*/
ByteArrayOutputStream os = new ByteArrayOutputStream();
workbook.write(os);
os.toByteArray(); workbook.close();
String httpUrl = null;
String filePath = null;
String url = null;
try {
url = FastDFSUtils.getDoUpload(sessionToken,fileName,os.toByteArray());
}catch (Exception e){
errLog("getDownloadAllStaffWorkers",ErrorCodeMsg.UNKNOWN_ERROR.getMessage(),"获取文件服务下载地址为空");
throw new AttemptException(ErrorCodeMsg.UNKNOWN_ERROR,"获取文件服务下载地址为空");
}
if (StringUtils.isNotEmpty(url)) {
JSONObject jsonObject = JSONObject.parseObject(url);
String data = jsonObject.getString("data");
JSONObject dataObject = JSONObject.parseObject(data);
httpUrl = dataObject.getString("httpUrl");
filePath = dataObject.getString("filePath");
if (StringUtils.isEmpty(filePath)) {
errLog("getDownloadTrainStuEnroll", ErrorCodeMsg.UNKNOWN_ERROR.getMessage(), "获取文件服务下载地址为空2");
throw new AttemptException(ErrorCodeMsg.UNKNOWN_ERROR, "获取文件服务下载地址为空2");
}
}
System.out.println(url);
Map<String,Object> map = new HashMap<>();
map.put("url",fileServer + "/" + filePath);
map.put("attname",fileName);
return map;
}
(3)Controller层代码
/**
* 下载员工
* @param request
* @param jsonParam
* @param requestUser
* @return
* @throws Exception
*/
@PostMapping("/getDownloadAllStaffWorkers")
public ResponseStruct getDownloadAllStaffWorkers(HttpServletRequest request,@RequestBody JSONObject jsonParam,@ModelAttribute RequestUser requestUser)throws Exception{
Long sysId = requestUser.getSysid();
String sessionToken = request.getHeader(ConstantsConfig.ACCESS_TOKEN_KEY);
jsonParam.put("sysId",sysId);
jsonParam.put("sessionToken",sessionToken);
Map<String,Object> map = allStaffWorkersInterface.getDownloadAllStaffWorkers(jsonParam);
return ResponseStruct.success(map);
} 注:因为前端框架是vue架构师考虑到整体文件的管理,所以这里面都要先把文件上传到fastdns服务器然后再进行处理。之前写过简单的。喜欢的点个赞谢谢!
 

完整版EXCEL导出 (大框架SpringCloud 业务还是Springboot一套)的更多相关文章

  1. 完整版excel上传导入读写批量数据并将反馈结果写入远程exel中

    思路:excel的读写借助于poi框架,在写入远程的时候,是不能直接写入的,本博主将传入的文件再次拉下来写到项目临时文件中,然后,在临时文件中写入,然后,以同样的名称路径覆盖掉远程的就可以了,稍微有点 ...

  2. 二十六、【开源框架】EFW框架Winform前端开发之Grid++Report报表、条形码、Excel导出、图表控件

    回<[开源]EFW框架系列文章索引>        EFW框架源代码下载V1.2:http://pan.baidu.com/s/1hcnuA EFW框架实例源代码下载:http://pan ...

  3. C#通过OLEDB导出大数据到Excel

    C#导出数据到Excel,基本有两种方法,一种方法是通过Microsoft.Office.Interop.Excel.Application,一行一列的写入Excel中:另一种方法是通过OLEDB,利 ...

  4. Winform .NET 利用NPOI导出大数据量的Excel

    前言:公司让做一个导出数据到Excel的小工具,要求是用户前端输入sql语句,点击导出按钮之后,将数据导出到Excel,界面如图所示:文件下端显示导出的进度 遇到的问题: 1.使用NPOI进行Exce ...

  5. abp框架Excel导出——基于vue

    abp框架Excel导出--基于vue 目录 abp框架Excel导出--基于vue 1.技术栈 1.1 前端采用vue,官方提供 1.2 后台是abp--aspnetboilerplate 2. E ...

  6. yii框架 excel导出

    环境: yii框架 basic版 1.下载 PHPexcel  (我用的是PHPExcel-1.8.1) 2.将下载的文件夹 (PHPExcel-1.8.1)放至 vender下  (路径:basic ...

  7. 阿里云96页报告详解《云上转型》(10个案例、10大趋势/完整版PPT)

    阿里云96页报告详解<云上转型>(10个案例.10大趋势/完整版PPT) 2017-12-29 14:20阿里云/云计算/技术 ﹃产业前沿超级干货﹄ ﹃数据观○重磅速递﹄ 阿里云研究中心云 ...

  8. poi 操作Excel 以及大数据量导出

    maven 依赖 (版本必须一致,否则使用SXSSFworkbook 时程序会报错) <dependency> <groupId>org.apache.poi</grou ...

  9. MySql数据库导出完整版(导出数据库,导出表,导出数据库结构)

    MySql数据库导出完整版(导出数据库,导出表,导出数据库结构) 用MySqlCE导出数据库脚本时,如数据库中包含中文内容,则导出异常. 现在可以通过mysqldump.exe直接导出数据库脚本步骤如 ...

随机推荐

  1. python基础——散列类型

    集合 集合具有不重复性,无序性的可变对象. 集合定义 直接定义 如:a = {'a','b',2} 别的类型转换,利用set    a = set(b) 其中b可以是一个列表或字符串等 增 add   ...

  2. iOS 自定义只有年月的DatePikerView

    头文件: @interface YearMonthPikerView : UIView @property (nonatomic,copy) void(^cancelBlock)(); @proper ...

  3. SecureCRT8.3

    https://blog.csdn.net/dff1993/article/details/81189610 这篇文章我试过,成功激活了SecureCRT8.3

  4. Codeforces Round #579 (Div. 3) Complete the Projects(贪心、DP)

    http://codeforces.com/contest/1203/problem/F1 Examples input 1 - - output 1 YES input 2 - - output 2 ...

  5. svn http

    yum install -y httpd subversion mod_dav_svn mkdir -p /var/lib/svn cd /var/lib/svn svnadmin create de ...

  6. ubuntu 14.04 搜狗拼音安装

    打开 Software & Updates,添加软件源: sudo add-apt-repository ppa:fcitx-team/nightly 输入 sudo apt-get inst ...

  7. mysql之存储过程(一)

    今天开发一个需求,需要在一个旧表中增加一列并且对已经的表中记录初始化新列的值, 由于是一次性的工作,故写了个存储过程来代替代码程序初始化 创建及执行过程记录如下: MySQL [XXX_YYY]> ...

  8. F. Moving On

    http://codeforces.com/gym/102222/problem/F fory #include<bits/stdc++.h> using namespace std; t ...

  9. TPO1-1 Groundwater

    If the pores are large,the water in them will exist as drops too heavy for surface tension to hold,a ...

  10. django的orm介绍以及静态文件介绍

    1 django中app的概念 大学:----------------- 项目 信息学院 ----------app01 物理学院-----------app02*强调:创建了app,要在配置文件中注 ...