spring boot读取Excel

Posted cangqinglang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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的解析。

以上是关于spring boot读取Excel的主要内容,如果未能解决你的问题,请参考以下文章

spring boot+vue实现excel导入导出

Spring Boot中如何读取resources目录下的文件

Java 读取Excel 文件存放到MySQL 数据库中,读取Excel 文件方法封装好的。用

spring mvc 读取数据库的二进制流生成excel文件

POI读取excel工具类(xls,xlsx通用)

java spring MVC 用poi做Excel导入碰到一个问题,求大神指教,有关下拉框的问题