spring boot读取Excel操作示例
2019-12-23 12:08
2967 查看
本文实例讲述了spring boot读取Excel操作。分享给大家供大家参考,具体如下:
首先引入相关依赖
<!--解析office相关文件--> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.17</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.17</version> </dependency> <!--解析office相关文件-->
工具类
import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.multipart.MultipartFile; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.util.HashMap; import java.util.Map; public class OfficeUtils { protected static final Logger logger = LoggerFactory.getLogger(OfficeUtils.class); public static Map<Integer, Map<Integer, Object>> readExcelContentz(MultipartFile file) throws Exception { Map<Integer, Map<Integer, Object>> content = new HashMap<Integer, Map<Integer, Object>>(); // 上传文件名 Workbook wb = getWb(file); if (wb == null) { throw new BusinessException(ErrorType.WORK_BOOK_EMPTY); } Sheet sheet = wb.getSheetAt(0); // 得到总行数 int rowNum = sheet.getLastRowNum(); Row row = sheet.getRow(0); int colNum = row.getPhysicalNumberOfCells(); // 正文内容应该从第二行开始,第一行为表头的标题 for (int i = 1; i <= rowNum; i++) { row = sheet.getRow(i); int j = 0; Map<Integer, Object> cellValue = new HashMap<Integer, Object>(); while (j < colNum) { Object obj = getCellFormatValue(row.getCell(j)); cellValue.put(j, obj); j++; } content.put(i, cellValue); } return content; } //根据Cell类型设置数据 private static Object getCellFormatValue(Cell cell) { Object cellvalue = ""; if (cell != null) { switch (cell.getCellTypeEnum()) { case NUMERIC: cellvalue = String.valueOf(cell.getNumericCellValue()); break; case FORMULA: { cellvalue = cell.getDateCellValue(); break; } case STRING: cellvalue = cell.getRichStringCellValue().getString(); break; default: cellvalue = ""; } } else { cellvalue = ""; } return cellvalue; } private static Workbook getWb(MultipartFile mf) { String filepath = mf.getOriginalFilename(); String ext = filepath.substring(filepath.lastIndexOf(".")); Workbook wb = null; try { InputStream is = mf.getInputStream(); if (".xls".equals(ext)) { wb = new HSSFWorkbook(is); } else if (".xlsx".equals(ext)) { wb = new XSSFWorkbook(is); } else { wb = null; } } catch (FileNotFoundException e) { logger.error("FileNotFoundException", e); } catch (IOException e) { logger.error("IOException", e); } return wb; } }
service层
public Map<Integer, Map<Integer,Object>> addCustomerInfo(MultipartFile file) { Map<Integer, Map<Integer,Object>> map = new HashMap<>(); try { map = ReadExcelUtil.readExcelContentz(file); } catch (Exception e) { e.printStackTrace(); } //excel数据存在map里,map.get(0).get(0)为excel第1行第1列的值,此处可对数据进行处理 }
controller层
@PostMapping public String add(@RequestParam("file")MultipartFile file){ Map<Integer, Map<Integer,Object>> map = customerService.addCustomerInfo(file); return "success"; }
至此,基本完成Excel的解析。
更多关于java相关内容感兴趣的读者可查看本站专题:《Spring框架入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
您可能感兴趣的文章:
- Springboot使用POI实现导出Excel文件示例
- Spring Boot Excel文件导出下载实现代码
- Springboot上传excel并将表格数据导入或更新mySql数据库的过程
- 使用Vue+Spring Boot实现Excel上传功能
- springboot实现上传并解析Excel过程解析
- SpringBoot使用POI进行Excel下载
- java springboot poi 从controller 接收不同类型excel 文件处理
- SpringMVC上传和解析Excel方法
- 详解poi+springmvc+springjdbc导入导出excel实例
- Spring 实现excel及pdf导出表格示例
相关文章推荐
- C# .Net :Excel NPOI导入导出操作教程之将Excel文件读取并写到数据库表,示例分享
- java poi读取excel操作示例(2个代码)
- python实现读取excel文件中所有sheet操作示例
- R语言读取Excel和对数据框的操作
- Java 操作 Excel (读取Excel2007,Poi实现)
- 生成/读取(反向更新数据库) Excel文件(示例代码下载)
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
- 使用poi操作导出excel代码示例
- python 读取文件 并实现文件相关操作最后导出excel
- C#操作Excel文件(读取Excel,写入Excel)
- jxl操作Excel(读取、创建、更新)
- C#操作Excel(读取)
- C#操作Excel(2)-- 打开-读取Excel文档
- Pandas读取并修改excel的示例代码
- 基于.NET的Excel开发:单元格区域的操作(读取、赋值、边框和格式)
- [导入]VB中操作Excel的一般做法(读取)
- Excel 二次开发系列(2): Excel 常用操作(创建、打开、读取、写入)
- C# winform 开发之Excel操作(二)------读取Excel表格
- Java读取excel的示例
- Excel应用程序对象(Application对象)及其常用方法基本操作应用示例