用poi从excel文档导入数据
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.web.multipart.MultipartFile; import java.io.IOException;
import java.math.BigDecimal;
import java.util.*; public class ImportExcelTool {
public static List<Map<String, String>> readExcel(MultipartFile file) throws IOException {
Workbook workbook = null;
String fileName = file.getOriginalFilename();
if (Objects.requireNonNull(fileName).endsWith(".xlsx"))
workbook = new XSSFWorkbook(file.getInputStream());
if (fileName.endsWith(".xls"))
workbook = new HSSFWorkbook(file.getInputStream());
Sheet sheet = Objects.requireNonNull(workbook).getSheetAt(0);
int physicalNumberOfRows = sheet.getPhysicalNumberOfRows(); Row row = sheet.getRow(1);
List<String> fieldNames = new ArrayList<>();
for (int i = 0; i < row.getLastCellNum(); i++)
fieldNames.add(row.getCell(i).getRichStringCellValue().getString()); List<Map<String, String>> lsMap = new ArrayList<>(); for (int j = 3; j < physicalNumberOfRows; j++) {
Map<String, String> dataMap = new HashMap<>();
Row dataRow = sheet.getRow(j);
if (dataRow == null)
break;
for (int i = 0; i < dataRow.getLastCellNum(); i++) {
String val = getCellValue(dataRow.getCell(i));
dataMap.put(fieldNames.get(i), val);
}
if (dataMap.size() == 0)
break; lsMap.add(dataMap);
}
return lsMap;
} private static String getCellValue(Cell cell) {
if (cell == null)
return "";
if (cell.getCellType() == CellType.NUMERIC)
if (DateUtil.isCellDateFormatted(cell))
return DateUtil.getJavaDate(cell.getNumericCellValue()).toString();
else
return new BigDecimal(cell.getNumericCellValue()).toString();
else if (cell.getCellType() == CellType.STRING)
return StringUtils.trimToEmpty(cell.getStringCellValue());
else if (cell.getCellType() == CellType.FORMULA)
return StringUtils.trimToEmpty(cell.getCellFormula());
else if (cell.getCellType() == CellType.BLANK)
return "";
else if (cell.getCellType() == CellType.BOOLEAN)
return String.valueOf(cell.getBooleanCellValue());
else if (cell.getCellType() == CellType.ERROR)
return "ERROR";
else
return cell.toString().trim(); }
}
用poi从excel文档导入数据的更多相关文章
- struts2中利用POI导出Excel文档并下载
1.项目组负责人让我实现这个接口,因为以前做过类似的,中间并没有遇到什么太困难的事情.其他不说,先上代码: package com.tydic.eshop.action.feedback; impor ...
- Java之Poi导出Excel文档
一.Poi简介 在后台管理系统中,我们经常要做的导出操作,通常导出为Excel文档的形式,而Poi则提供了这种需要的支持. 二.Workbook/HSSFWorkbook/XSSFWorkbook 1 ...
- POI 读取Excel文档中的数据——兼容Excel2003和Excel2007
Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. HSSF - 提供读写Microsoft Exce ...
- POI导出Excel文档通用工具方法
import java.lang.reflect.InvocationTargetException; import java.util.List; import java.util.Map; imp ...
- 使用struts2和poi导出excel文档
poi眼下应该是比較流行的操作excel的工具了.这几天做了个struts2和poi结合使用来实现导出excel的功能.个人认为还是比較有用的.代码阅读起来也非常easy.下来就来分享下我的心得 1 ...
- excel文档中数据导入sql server注意事项
进来经常需要对一些基础数据进行更新,而业务方提供的数据源往往都是excel,所以经常需要将excel中数据导入到 数据库临时表,然后再进行处理. 在导入过程中,发现有些数据比如手机号码,如果默认导入, ...
- POI之Excel文档增删改查
需要引用apache第三方lib库poi 支持xls.xlsx格式excel读写操作 package com.hua.excel; import java.io.File;import java.io ...
- 【Java】常用POI生成Excel文档设置打印样式
package poi_test; import java.io.FileOutputStream; import java.io.IOException; import org.apache.poi ...
- 怎么对比两个excel文档的数据差异
百度经验: https://jingyan.baidu.com/article/6181c3e0877c7a152ef15304.html
随机推荐
- Django学习系列18:使用迁移创建生产数据库
Django生成一个很有帮助的错误信息,大意是说没有正确设置数据库. 你可能会有疑惑,为什么在单元测试一切都运行ok,这是因为Django为单元测试创建了专用的测试数据库——这是Django中Test ...
- 前端面试题-BFC(块格式化上下文)
一.BFC 的概念 1.规范解释 块格式化上下文(Block Formatting Context,BFC)是Web页面的可视化CSS渲染的一部分,是布局过程中生成块级盒子的区域,也是浮动元素与其他元 ...
- Elasticsearch在Centos 7上的安装与配置
https://segmentfault.com/a/1190000011899522 https://blog.csdn.net/xxxxxx91116/article/details/171362 ...
- HTML左边盒子固定,右边盒子自适应
html: <div class="box1"> <div class="divA">DIVA</div> <div ...
- Python 3标准库 第五章 数学运算
第五章数学运算-----------------------上下文解释:编程时,我们一般也是先给程序定义一些前提(环境变量.描述环境变化的全局变量等),这些“前提”就是上文,然后再编写各功能模块的代码 ...
- echarts 图形图例文字太长如何解决
文章来源: https://blog.csdn.net/csm17805987903/article/details/85111835 legend 文字很多的时候对文字做裁剪并且开启 tooltip ...
- HDU 6191 Query on A Tree ( 2017广西邀请赛 && 可持久化Trie )
题目链接 题意 : 给你一棵树.树上的每个点都有点权.之后有若干次问询.每次问询给出一个节点编号以及一个整数 X .问你以给出节点为根的子树中哪个节点和 X 异或最大.输出这个值 分析 : 看到这种树 ...
- 【WC2016】论战捆竹竿
已经快三周了啊--终于把挖的坑填了-- 首先显然是把除了自身的所有border拿出来,即做 \(\left\{ n - b_1, n - b_2, \dots, n - b_k, n \right\} ...
- (转载)rabbitmq与springboot的安装与集成
原文地址:https://segmentfault.com/a/1190000016991529 一.前言 RabbitMQ是一个开源的消息代理软件(面向消息的中间件),它的核心作用就是创建消息队列, ...
- AcWing:105. 七夕祭(前缀和 + 中位数 + 分治 + 贪心)
七夕节因牛郎织女的传说而被扣上了「情人节」的帽子. 于是TYVJ今年举办了一次线下七夕祭. Vani同学今年成功邀请到了cl同学陪他来共度七夕,于是他们决定去TYVJ七夕祭游玩. TYVJ七夕祭和11 ...