excel文件导入或导出Java代码示例

1、excel文件导入

controller层接口内容

 service层代码

 

 serviceImpl内代码内容

 @Override@Transactional(rollbackFor = Exception.class)public void importCheckItemExcel(MultipartFile file, Long checkPkgId) throws Exception {if (file.isEmpty()){throw new IOException("请选择上传文件");}Workbook work = this.getWorkbook(file);if (null == work) {throw new HolliException(DeviceExceptionEnum.EXCEL_IS_NULL_EXCEPTION);}Iterator<Sheet> sheetIterator = work.sheetIterator();while (sheetIterator.hasNext()) {Sheet sheet = sheetIterator.next();if (sheet == null) {return;}//先获取首列标题Map<String, Integer> validColumns = new HashMap<>();List<String> headerCells = getFirstRow(sheet, 0);if (headerCells == null) {return;}for (int i = 0; i < headerCells.size(); i++) {Object header = headerCells.get(i);if (header == null) {continue;}if (ObjectUtil.contains(header, "修程")) {
//                    validColumns.put("checkLevel", i);//数字validColumns.put("checkLevelName", i);//含义}else if (ObjectUtil.contains(header, "工作项目")) {validColumns.put("checkName", i);}else if (ObjectUtil.contains(header, "单位")) {
//                    validColumns.put("checkUnit", i);//数字validColumns.put("checkUnitName", i);//含义}else if (ObjectUtil.contains(header, "周期")) {validColumns.put("checkCycle", i);}else if (ObjectUtil.contains(header, "工作内容及标准")) {validColumns.put("checkContent", i);}else if (ObjectUtil.contains(header, "ATP型号")) {validColumns.put("atpModel", i);}}
//标题集合if (validColumns.size() == 0) {return;}Map<String, Object> map = new HashMap<String, Object>();//遍历当前sheet中的所有行//包涵头部,所以要小于等于最后一列数,这里也可以在初始值加上头部行数,以便跳过头部for (int j = 1; j <= sheet.getLastRowNum(); j++) {//读取一行List<Object> rows = getRow(sheet, j);if (rows == null) {continue;}Set<String> keySet = validColumns.keySet();for (String key : keySet) {int col_index = validColumns.get(key);if (col_index >= rows.size()) {continue;}Object cell = rows.get(col_index);map.put(key, cell);}
//取出对应属性及值内容 以便存储数据库//业务逻辑,数据存储DevCheckItemVo devCheckItemVo = new DevCheckItemVo();BeanUtil.copyProperties(map, devCheckItemVo);this.insertDevCheckItem(checkPkgId, devCheckItemVo, j + 1);}}}

 判断excel的格式,同时兼容2003和2007

protected final static String excel2003L = ".xls";    //2003- 版本的excelprotected final static String excel2007U = ".xlsx";   //2007+ 版本的excel/*** 描述:根据文件后缀,自适应上传文件的版本*/public static Workbook getWorkbook(MultipartFile file) throws Exception {Workbook wb = null;InputStream is = file.getInputStream();String fileType = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));if (excel2003L.equals(fileType)) {wb = new XSSFWorkbook(is);  //2007+
//            因HSSFWorkbook报(You need to call a different part of POI to process this data (eg XSSF instead of HSSF)),故直接使用XSSFWorkbook处理
//            wb = new HSSFWorkbook(is);  //2003-} else if (excel2007U.equals(fileType)) {wb = new XSSFWorkbook(is);  //2007+} else {throw new IOException("解析的文件格式有误!");}return wb;}

 获取行数据

/*** 获取行数据* @param sheet* @param rowIndex* @return*/public List<Object> getRow(Sheet sheet, int rowIndex) {List<Object> li = new ArrayList<Object>();if (sheet == null) {return null;}Row row = null;Cell cell = null;//读取一行row = sheet.getRow(rowIndex);//去掉空行和表头if (row == null) {return null;}/**为去掉空行,若第一列为空,则直接跳过该行*/if (ObjectUtil.isEmpty(row.getCell(0))) {return null;}//遍历所有的列for (int y = row.getFirstCellNum(); y < row.getLastCellNum(); y++) {cell = row.getCell(y);li.add(this.getCellFormatValue(cell));}return li;}

 //获取excel列表内的对应数据格式


//获取excel列表内的对应数据格式protected Object getCellFormatValue(Cell cell) {Object val = "";if (null != cell) {if (cell.getCellType() == CellType.NUMERIC || cell.getCellType() == CellType.FORMULA){val = cell.getNumericCellValue();if (DateUtil.isCellDateFormatted(cell)){val = DateUtil.getJavaDate((Double) val); // POI Excel 日期格式转换}else{if ((Double) val % 1 != 0){val = new BigDecimal(val.toString());}else{val = new DecimalFormat("0").format(val);}}}else if (cell.getCellType() == CellType.STRING){val = cell.getStringCellValue();}else if (cell.getCellType() == CellType.BOOLEAN){val = cell.getBooleanCellValue();}else if (cell.getCellType() == CellType.ERROR){val = cell.getErrorCellValue();}} else {val = "";}return val;}

 2、excel导出

controller层接口内容

  service层代码

  serviceImpl内代码内容

 @Overridepublic void exportCheckItemExcel(String strIds, HttpServletResponse response) throws Exception {List<DevCheckItem> devCheckItemList = new ArrayList<>();long[] itemIdArray = StrUtil.splitToLong(strIds,",");//查询检修项idfor (int i = 0; i< itemIdArray.length; i++){DevCheckItem devCheckItem = this.getById(itemIdArray[i]);if (ObjectUtil.isNotEmpty(devCheckItem)){devCheckItemList.add(devCheckItem);}}if (ObjectUtil.isNotEmpty(devCheckItemList) && devCheckItemList.size() > 0){//导出excelXSSFWorkbook workbook=new XSSFWorkbook();//获得名字为sheet的工作本对象,这个是看你的模板工作表的名字XSSFSheet sheet = workbook.createSheet("sheet1");// 序号int serialNo = 1;//行号int rowIndex = 1;//创建表头XSSFRow row_excel = sheet.createRow(0);//行业务数据填充XSSFCell cell = row_excel.createCell(0);cell.setCellValue("序号");cell = row_excel.createCell(1);cell.setCellValue("ATP型号");cell = row_excel.createCell(2);cell.setCellValue("修程");cell = row_excel.createCell(3);cell.setCellValue("工作项目");cell = row_excel.createCell(4);cell.setCellValue("单位");cell = row_excel.createCell(5);cell.setCellValue("周期(小时)");cell = row_excel.createCell(6);cell.setCellValue("工作内容及标准");//遍历填充数据for (DevCheckItem devCheckItem : devCheckItemList){//获取当前行row_excel = sheet.getRow(rowIndex);if (row_excel == null){//创建行row_excel = sheet.createRow(rowIndex);}//内容填充if (ObjectUtil.isNotEmpty(devCheckItem)){XSSFCell cellNew = row_excel.createCell(0);cellNew.setCellValue(serialNo);cell = row_excel.createCell(1);if (ObjectUtil.isNotEmpty(devCheckItem.getAtpModel())){cell.setCellValue(devCheckItem.getAtpModel());}cell = row_excel.createCell(2);if (ObjectUtil.isNotEmpty(devCheckItem.getCheckLevel())){String levelName = DevCheckLevelEnum.getLevelNameByType(devCheckItem.getCheckLevel());cell.setCellValue(levelName);}cell = row_excel.createCell(3);if (ObjectUtil.isNotEmpty(devCheckItem.getCheckName())){cell.setCellValue(devCheckItem.getCheckName());}cell = row_excel.createCell(4);if (ObjectUtil.isNotEmpty(devCheckItem.getCheckUnit())){String checkUnit = this.getCheckUnitNameByNum(devCheckItem.getCheckUnit());cell.setCellValue(checkUnit);}cell = row_excel.createCell(5);if (ObjectUtil.isNotEmpty(devCheckItem.getCheckCycle())){cell.setCellValue(devCheckItem.getCheckCycle());}cell = row_excel.createCell(6);if (ObjectUtil.isNotEmpty(devCheckItem.getCheckContent())){cell.setCellValue(devCheckItem.getCheckContent());}}serialNo++;rowIndex++;}response.setCharacterEncoding("UTF-8");response.setHeader("Content-Type", "application/vnd.ms-excel");ServletOutputStream out = response.getOutputStream();workbook.write(out);}}

以上已导出完成。

3、以下为可能会用到的导出实例文件,上传文件服务器的过程 

File格式转换MultipartFile格式的例子

//上传minio服务器
String fileName = "检修工作项目.xlsx";
File cacheFile = new File(fileName);
if (cacheFile.exists()) {cacheFile.delete();
}cacheFile.createNewFile();//生成文件
OutputStream out = new FileOutputStream(cacheFile);
workbook.write(out);
---------------------------------------------------------------------------------------(上面为导出实例文件)
//下面为上传文件流格式转换的格式。
FileInputStream fileInputStream = new FileInputStream(cacheFile);
MultipartFile multipartFile = new MockMultipartFile("cacheFile", cacheFile.getName(), "text/plain", IOUtils.toByteArray(fileInputStream));

 

-------------------------------------以下无正文-----------------------------------------------------------

注:仅供学习,记录问题和参考,共勉!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/3967.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 中 synchronized 的优化操作:锁升级、锁消除、锁粗化

由 并发编程中常见的锁策略 总结可知&#xff0c;synchronized 具有以下几个特性&#xff1a; 开始时是乐观锁&#xff0c;如果锁冲突频繁&#xff0c;就转换为悲观锁。开始是轻量级锁实现&#xff0c;如果锁被持有的时间较长&#xff0c;就转换成重量级锁。实现轻量级锁时&am…

Spring Cloud Alibaba【Nacos配置动态刷新、Nacos集群架构介绍 、Nacos的数据持久化、认识分布式流量防护 】(五)

目录 分布式配置中心_Nacos配置动态刷新 分布式配置中心_Dubbo服务对接分布式配置中心 分布式配置中心_Nacos集群架构介绍 分布式配置中心_Nacos的数据持久化 分布式配置中心_Nacos集群配置 分布式流量防护_认识分布式流量防护 分布式流量防护_认识Sentinel 分布式配置…

pycharm里debug时torch数组显示不全

pycharm里查看torch数组全部值 一、在Pycharm运行torch数组时&#xff0c;通常只能看到数组的一部分二、解决办法1、debug后&#xff0c;鼠标右键想要查看完整的数组&#xff0c;选择Evaluate Expression2、输入np.array(x0.data)&#xff0c;x0为想要查看的数组名&#xff0c;…

在Linux下做性能分析1:基本模型

介绍 本Blog开始介绍一下在Linux分析性能瓶颈的基本方法。主要围绕一个基本的分析模型&#xff0c;介绍perf和ftrace的使用技巧&#xff0c;然后东一扒子&#xff0c;西一扒子&#xff0c;逮到什么说什么&#xff0c;也不一定会严谨。主要是把这个领域的一些思路和技巧串起来。…

Flutter悬浮UI的设计Overlay组件

文章目录 APP开发经常要遇到的开发场景Overlay 的介绍Overlay的使用规则举例说明源码例子报错报错No Overlay widget found报错原因解决方法 修改后的源码 例子效果 APP开发经常要遇到的开发场景 有时候我们在开发APP的时候会遇到下面这些需求&#xff1a; 在现有页面上添加浮…

代码随想录算法训练营第十九天 | 动态规划系列5,6,7,8

动态规划系列5,6,7,8 377 组合总和 Ⅳ未看解答自己编写的青春版重点代码随想录的代码我的代码(当天晚上理解后自己编写)求排列数的题&#xff0c;用二维DP过不了&#xff1f;自己捋逻辑的话&#xff0c;也是可以觉得有漏洞&#xff0c;但是怎么修改&#xff0c;一下子还没思路&…

JVM之内存与垃圾回收篇2

文章目录 3 运行时区域3.1 本地方法栈3.2 程序计数器3.3 方法区3.3.1 Hotspot中方法区的演进3.3.2 设置方法区内存大小3.3.3 运行时常量池3.3.4 方法区使用举例3.3.5 方法区的演进3.3.5 方法区的垃圾回收 3.4 栈3.4.1 几个面试题 3.5 堆3.5.1 Minor GC、Major GC和Full GC3.5.2…

适配器模式-不兼容结构的协调

去英语国家旅游时&#xff0c;我们只会说中文&#xff0c;为了与当地人交流&#xff0c;我们需要购买个翻译器&#xff0c;将中文翻译成英文&#xff0c;而这运用了适配器模式。 1 概述 适配器模式&#xff08;Adapter Pattern&#xff09;&#xff0c;将一个接口转换成客户喜…

idea-控制台输出乱码问题

idea-控制台输出乱码问题 现象描述&#xff1a; 今天在进行IDEA开发WEB工程调式的时候控制台日志输出了乱码&#xff0c;如下截图 其实开发者大多都知道乱码是 编码不一致导致的&#xff0c;但是有时候就是不知到哪些地方不一致&#xff0c;今天我碰到的情况可能和你的不相同…

APACHE KAFKA本机Hello World教程

目标 最近想要简单了解一下Apache Kafka&#xff0c;故需要在本机简单打个Kafka弄一弄Hello World级别的步骤。 高手Kafka大佬们&#xff0c;请忽略这里的内容。 步骤 Apacha Kafka要求按照Javak8以上版本的环境。从官网下载kafka并解压。 启动 # 生产kafka集群随机ID KA…

未来Mac下载站怎么打不开了

重要公告&#xff1a; 未来软件园因业务需要现更换域名 原域名&#xff1a;Mac.orsoon.com 更为新域名&#xff1a;未来mac下载-Mac软件-mac软件下载-mac软件大全 程序已全面转移&#xff0c;请访问新域名

软件基础问答题

性能&#xff1a; 负载压力测试是指在一定约束条件下测试系统所能承受的并发用户量、运行时间、数据量等&#xff0c;以确定系统所能承受的最大负载压力。 负载测试是通过逐步增加系统负载&#xff0c;测试系统性能的变化&#xff0c;并最终确定在满足性能指标的情况下&#xf…

【技能实训】DMS数据挖掘项目-Day11

文章目录 任务12【任务12.1】创建用户信息表【任务12.2】在com.qst.dms.entity下创建用户实体类User&#xff0c;以便封装用户数据【任务12.3】在com.qst.dms.service下创建用户业务类UserService【任务12.4】在项目根目录下创建图片文件夹images&#xff0c;存储dms.png【任务…

计算机毕业论文选题推荐|软件工程|信息管理|数据分析|系列一

文章目录 导文题目导文 计算机毕业论文选题推荐|软件工程|信息管理 (***语言)==使用其他任何编程语言 例如:基于(***语言)门窗账务管理系统的设计与实现 得到:基于JAVA门窗账务管理系统的设计与实现 基于vue门窗账务管理系统的设计与实现 等等 题目 基于requests多线程…

微信小程序——字符串截取

indexOf() &#xff1a; 判断一个字符是否在字符串 中 存在&#xff0c;如果存在返回该元素或字符第一次出现 的 位置 的 索引&#xff0c;不存在返回-1。 lastIndexOf() &#xff1a; 返回一个指定的字符串值最后出现的位置&#xff0c;在一个字符串中的指定位置从后向前搜索。…

静态数码管显示

学习芯片&#xff1a; EP4CE6F17C8 本次学习使用的为共阴极数码管&#xff0c;即用低电平点亮数码管&#xff0c;同样可知&#xff0c;共阳极数码管的阳极连在一起&#xff0c;即用高电平点亮数码管。 八段数码管示意图&#xff1a; a,b,c,d,e,f,g,dg表示八段数码管时&#…

7、sentinel使用和源码分析

一、分布式系统遇到的问题 1、服务雪崩效应 在分布式系统中,由于网络原因或自身的原因,服务一般无法保证 100% 可用。如果一个服务出现了问题&#xff0c;调用这个服务就会出现线程阻塞的情况&#xff0c;此时若有大量的请求涌入&#xff0c;就会出现多条线程阻塞等待&#x…

力扣 135. 分发糖果

题目来源&#xff1a;https://leetcode.cn/problems/candy/description/ C题解&#xff08;来源代码随想录&#xff09;&#xff1a; 先从左往右比较&#xff0c;右边孩子评分比左边高就多发1颗糖&#xff0c;否则就只发1颗&#xff1b;再从右往左比较&#xff0c;左边孩子评分…

机械臂的雅克比矩阵推导

1. 线速度和角速度的递推通式推导 p i p i − 1 R i − 1 r i − 1 , i i − 1 \mathbf{p}_{i}\mathbf{p}_{i-1}\mathbf{R}_{i-1} \mathbf{r}_{i-1, i}^{i-1} pi​pi−1​Ri−1​ri−1,ii−1​ p i − 1 \mathbf{p}_{i-1} pi−1​是 { i − 1 } \{i-1\} {i−1}坐标系的原点的…

记一次ruoyi中使用Quartz实现定时任务

一、首先了解一下Quartz Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目&#xff0c;它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个&#xff0c;百个&#xff0c;甚至是好几万个Jobs这样复杂的程序。Jobs可以做成标…