这里用的是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. [SDOI2019]世界地图(kruskal重构树+虚树)

    通过子任务1.3十分显然,子任务4实际上就是线段树,和我下午写的[SDOI2015]道路修建一模一样,堪称“我抄我自己”,不会的可以先做一下这个题. 然后考虑正解,参考了zhoushuyu的博客,首先 ...

  2. Java--面向对象三大特征-->封装、继承、多态

    简介 在面向过程当中只有存在封装(对功能的封装 例如c语言中的函数),而在面向对象中才存在这三大特性. 继承 -->inheritance 1.子类可以从父类继承属性和方法(除去父类私有化的方法 ...

  3. 三十八、LNMP潮流组合搭建

    一.安装mysql 数据库 1.1  mysql数据库安装的三种方法: 1)编译安装,在lamp经典组合安装是5.1版本,是configure,make,make install,这里如果是5.5版本 ...

  4. E - Minimum Spanning Tree Gym - 102220E (转化+贡献)

    In the mathematical discipline of graph theory, the line graph of a simple undirected weighted graph ...

  5. 比率(ratio)|帕雷托图|雷达图|轮廓图|条形图|茎叶图|直方图|线图|折线图|间隔数据|比例数据|标准分数|标准差系数|离散系数|平均差|异众比率|四分位差|切比雪夫|右偏分布|

    比率是什么? 比率(ratio) :不同类别数值的比值 在中文里,比率这个词被用来代表两个数量的比值,这包括了两个相似却在用法上有所区分的概念:一个是比的值:另一是变化率,是一个数量相对于另一数量的变 ...

  6. 安装Rational Rose启动报错:无法启动此程序,因为计算机中丢失 suite objects.dll。

    运行Rational Rose的时候如果出现这样的错误,先检查环境变量有没有common的地址,如果没有直接配上就OK:配置如下:D:\Program Files\Rational\Common; 我 ...

  7. django-crontab使用

    用 django-crontab 为 Django 添加定时任务 需求 做后台开发的时候,有时候会遇到这样的需求,在某个固定时间或者一定时间间隔自动触发某一事件.比如说我有一个需求要求是,周一到周五早 ...

  8. COMET探索系列二【Ajax轮询复用模型】

    写在前面:Ajax轮询相信大家都信手拈来在用,可是有这么一个问题,如果一个网站中同时有好多个地方需要用到这种轮询呢?就拿我们网站来说,有一个未读消息数提醒.还有一个时实时加载最新说说.昨天又加了一个全 ...

  9. 77)PHP,将session数据写到不用的存储介质中

    首先我的siession数据可以写到:文件中    session数据区  或者数据库中, 那么怎么将文件中的session数据或者session数据区的数据写到  数据库中,,又或者任意挑选两个不同 ...

  10. Angular开发者指南(五)服务

    服务 AngularJS服务是使用依赖注入(DI)连接在一起的可替代对象. 可以使用服务在整个应用程式中整理和分享程式码. AngularJS服务有: 延迟初始化 - AngularJS只在应用程序组 ...