完整版EXCEL导出 (大框架SpringCloud 业务还是Springboot一套)
这里用的是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一套)的更多相关文章
- 完整版excel上传导入读写批量数据并将反馈结果写入远程exel中
思路:excel的读写借助于poi框架,在写入远程的时候,是不能直接写入的,本博主将传入的文件再次拉下来写到项目临时文件中,然后,在临时文件中写入,然后,以同样的名称路径覆盖掉远程的就可以了,稍微有点 ...
- 二十六、【开源框架】EFW框架Winform前端开发之Grid++Report报表、条形码、Excel导出、图表控件
回<[开源]EFW框架系列文章索引> EFW框架源代码下载V1.2:http://pan.baidu.com/s/1hcnuA EFW框架实例源代码下载:http://pan ...
- C#通过OLEDB导出大数据到Excel
C#导出数据到Excel,基本有两种方法,一种方法是通过Microsoft.Office.Interop.Excel.Application,一行一列的写入Excel中:另一种方法是通过OLEDB,利 ...
- Winform .NET 利用NPOI导出大数据量的Excel
前言:公司让做一个导出数据到Excel的小工具,要求是用户前端输入sql语句,点击导出按钮之后,将数据导出到Excel,界面如图所示:文件下端显示导出的进度 遇到的问题: 1.使用NPOI进行Exce ...
- abp框架Excel导出——基于vue
abp框架Excel导出--基于vue 目录 abp框架Excel导出--基于vue 1.技术栈 1.1 前端采用vue,官方提供 1.2 后台是abp--aspnetboilerplate 2. E ...
- yii框架 excel导出
环境: yii框架 basic版 1.下载 PHPexcel (我用的是PHPExcel-1.8.1) 2.将下载的文件夹 (PHPExcel-1.8.1)放至 vender下 (路径:basic ...
- 阿里云96页报告详解《云上转型》(10个案例、10大趋势/完整版PPT)
阿里云96页报告详解<云上转型>(10个案例.10大趋势/完整版PPT) 2017-12-29 14:20阿里云/云计算/技术 ﹃产业前沿超级干货﹄ ﹃数据观○重磅速递﹄ 阿里云研究中心云 ...
- poi 操作Excel 以及大数据量导出
maven 依赖 (版本必须一致,否则使用SXSSFworkbook 时程序会报错) <dependency> <groupId>org.apache.poi</grou ...
- MySql数据库导出完整版(导出数据库,导出表,导出数据库结构)
MySql数据库导出完整版(导出数据库,导出表,导出数据库结构) 用MySqlCE导出数据库脚本时,如数据库中包含中文内容,则导出异常. 现在可以通过mysqldump.exe直接导出数据库脚本步骤如 ...
随机推荐
- python基础——散列类型
集合 集合具有不重复性,无序性的可变对象. 集合定义 直接定义 如:a = {'a','b',2} 别的类型转换,利用set a = set(b) 其中b可以是一个列表或字符串等 增 add ...
- iOS 自定义只有年月的DatePikerView
头文件: @interface YearMonthPikerView : UIView @property (nonatomic,copy) void(^cancelBlock)(); @proper ...
- SecureCRT8.3
https://blog.csdn.net/dff1993/article/details/81189610 这篇文章我试过,成功激活了SecureCRT8.3
- 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 ...
- svn http
yum install -y httpd subversion mod_dav_svn mkdir -p /var/lib/svn cd /var/lib/svn svnadmin create de ...
- ubuntu 14.04 搜狗拼音安装
打开 Software & Updates,添加软件源: sudo add-apt-repository ppa:fcitx-team/nightly 输入 sudo apt-get inst ...
- mysql之存储过程(一)
今天开发一个需求,需要在一个旧表中增加一列并且对已经的表中记录初始化新列的值, 由于是一次性的工作,故写了个存储过程来代替代码程序初始化 创建及执行过程记录如下: MySQL [XXX_YYY]> ...
- F. Moving On
http://codeforces.com/gym/102222/problem/F fory #include<bits/stdc++.h> using namespace std; t ...
- TPO1-1 Groundwater
If the pores are large,the water in them will exist as drops too heavy for surface tension to hold,a ...
- django的orm介绍以及静态文件介绍
1 django中app的概念 大学:----------------- 项目 信息学院 ----------app01 物理学院-----------app02*强调:创建了app,要在配置文件中注 ...