本文实例讲述了spring boot读取Excel操作。分享给大家供大家参考,具体如下:
成都创新互联公司长期为成百上千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为阳新企业提供专业的成都做网站、成都网站设计,阳新网站改版等技术服务。拥有十多年丰富建站经验和众多成功案例,为您定制开发。
首先引入相关依赖
<!--解析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读取Excel操作示例
网页路径:https://www.cdcxhl.com/article34/pdihse.html
成都网站建设公司_创新互联,为您提供网站收录、自适应网站、网页设计公司、网站设计公司、网站策划、App开发
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联