使用easyexcel导入excel

//controller 
@GetMapping("/importExcel")
	public  importExcel(@RequestParam("file") MultipartFile file){
		service.import(file);
	}
//service
void import(MultipartFile file);


@Override
	public void import(MultipartFile file){
		ExcelReader excelReader = null;
		try {
			if (file.getOriginalFilename() == null || (!file.getOriginalFilename().toLowerCase().endsWith(".xls") && !file.getOriginalFilename().toLowerCase().endsWith(".xlsx"))) {
				throw new BadException("");
			}
			if (file.getOriginalFilename().endsWith(".xlsx")) {
				file.getOriginalFilename().replace(".xlsx", ".xls");
			}
			InputStream inputStream = file.getInputStream();
			//开始读取数据
			excelReader = EasyExcel.read(inputStream).build();

			importData(excelReader);

		} catch (IOException | BadException e) {
			throw new BadException("");
		} finally {
			if (excelReader != null) {
				// 关闭
				excelReader.finish();
			}
		}
	}

	public void importData(ExcelReader excelReader) {
		ExcelListener excelListener = new ExcelListener();
		ReadSheet readSheet = EasyExcel.readSheet("Sheet1").headRowNumber(2).head(ExcelImportTemp.class).registerReadListener(excelListener).build();

		excelReader.read(readSheet);
		List<ExcelImportTemp> dataList = excelListener.getDataList();
		System.out.println(dataList);
		//将获取到的数据做处理
		

	}
//基础数据类
@Slf4j
public class ExcelListener extends AnalysisEventListener<ExcelImportTemp> {


	private List<ExcelImportTemp> dataList = new ArrayList<ExcelImportTemp>();

	@Override
	public void invoke(ExcelImportTemp data, AnalysisContext context) {
		log.info("读取了一条数据:{}", JSON.toJSONString(data));
		dataList.add(data);
	}

	@Override
	public void doAfterAllAnalysed(AnalysisContext context) {
		log.info("读取完毕,共:{}条",dataList.size());

	}

	public List<ExcelImportTemp> getDataList() {
		int sheetNo = 3;
		for (ExcelImportTemp data : dataList) {
			data.setSheetName("Sheet1");
			data.setSheetLineNo(sheetNo);
			sheetNo+=1;
		}
		return dataList;
	}




@Data
public class ExcelImportTemp {


	@ExcelIgnore
	private Integer id;
	/**
	 * sheet序号
	 */
	@ExcelIgnore
	private String sheetName;
	/**
	 * sheet中第几行
	 */
	@ExcelIgnore
	private Integer sheetLineNo;
	/**
	 * 名称***
	 */

	@ExcelProperty(value = {"英文名称"}, index = 0)
	private Integer a;

	@ExcelProperty(value = {"定额工日", "建筑"}, index = 1)
	private Integer b;
}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值