spring boot读取Excel操作示例

网友投稿 309 2022-12-23


spring boot读取Excel操作示例

本文实例讲述了spring boot读取Excel操作。分享给大家供大家参考,具体如下:

首先引入相关依赖

org.apache.poi

poi

3.17

org.apache.poi

poi-ooxml

3.17

工具类

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.gZcZGOQVaFxetLogger(OfficeUtils.class);

public static Map> readExcelContentz(MultipartFile file) throws Exception {

Map> content = new HashMap>();

// 上传文件名

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 cellValue = new HashMap();

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> addCustomerInfo(MultipartFile file) {

Map> 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> map = customerService.addCustomerInfo(file);

return "success";

}

至此,基本完成Excel的解析。

更多关于java相关内容感兴趣的读者可查看本站专题:《Spring框架入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

希望本文所述对大家java程序设计有所帮助。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java文件如何统计字母出现的次数和百分比
下一篇:java 线程方法join简单用法实例总结
相关文章

 发表评论

暂时没有评论,来抢沙发吧~