如何实现批量上传----------Java解析excel
一、引子
在web平台开发中仅经常会遇到一下需要批量的问题,通常得做法是使用excel上传,下面主要介绍一下在实际开发中到的实例。
二、准备工作
1、需要导入的jar包(主要用到poi包)
(1)poi-3.14.jar
(2)poi-ooxml-3.14.jar
(3)poi-ooxml-schemas-3.14.jar
(4)xmlbeans-2.6.0.jar
2、主要的API
(1)import org.apache.poi.ss.usermodel.Workbook,对应Excel文档;
(2)import org.apache.poi.hssf.usermodel.HSSFWorkbook,对应xls格式的Excel文档;
(3)import org.apache.poi.xssf.usermodel.XSSFWorkbook,对应xlsx格式的Excel文档;
(4)import org.apache.poi.ss.usermodel.Sheet,对应Excel文档中的一个sheet;
(5)import org.apache.poi.ss.usermodel.Row,对应一个sheet中的一行;
(6)import org.apache.poi.ss.usermodel.Cell,对应一个单元格。
三、上代码
excel格式:

代码:
1 package text;
2
3 import java.io.File;
4 import java.io.FileInputStream;
5 import java.io.InputStream;
6 import java.util.ArrayList;
7 import java.util.HashMap;
8 import java.util.LinkedHashMap;
9 import java.util.List;
10 import java.util.Map;
11
12 import org.apache.poi.hssf.usermodel.HSSFWorkbook;
13 import org.apache.poi.ss.usermodel.Cell;
14 import org.apache.poi.ss.usermodel.Row;
15 import org.apache.poi.ss.usermodel.Sheet;
16 import org.apache.poi.ss.usermodel.Workbook;
17 import org.apache.poi.xssf.usermodel.XSSFWorkbook;
18
19 public class ExcelSolution {
20 public static void main(String[] args) {
21 String filePath = "E:\\XXXXupload\\地点.xlsx";
22 List<Map<String,String>> resultList =ExcelUtil(filePath);
23 for (Map map : resultList) {
24 System.out.println(map);
25 }
26 }
27 public static List<Map<String,String>> ExcelUtil(String filePath){
28 ArrayList<Map<String,String>> reList = new ArrayList<Map<String,String>>();
29 File file = new File(filePath);
30 Workbook wb=null;
31 if(file.exists() && file.isFile()){
32 try {
33 if(filePath.toLowerCase().endsWith(".xls")){
34 wb = new HSSFWorkbook(new FileInputStream(file));
35 }else if (filePath.toLowerCase().endsWith(".xlsx")) {
36 wb = new XSSFWorkbook(new FileInputStream(file));
37 }
38 Sheet sheet =wb.getSheetAt(0);
39 int rowNum = sheet.getPhysicalNumberOfRows(); //获取行数
40 if (rowNum >1) {
41 for (int i = 1; i < rowNum; i++) {
42 Map<String, String> map = new HashMap<String, String>();
43 Row row = sheet.getRow(i);
44 if (row!=null) {
45 // 第一列:省份
46 Cell cell0 = sheet.getRow(i).getCell(0);
47 if(cell0 != null && !"".equals(cell0)){
48 String Name =(String) cell0.getStringCellValue().trim();
49 map.put("name", Name);
50 }
51 Cell cell1 = sheet.getRow(i).getCell(1);
52 if(cell1 != null && !"".equals(cell1)){
53 String provinceName = (String)cell1.getStringCellValue().trim();
54 map.put("provinceName", provinceName);
55 }
56 Cell cell2 = sheet.getRow(i).getCell(2);
57 if(cell0 != null && !"".equals(cell2)){
58 String cityName = (String)cell2.getStringCellValue().trim();
59 map.put("cityname", cityName);
60 }
61
62 reList.add(map);
63 }
64
65 }
66
67 }
68 } catch (Exception e) {
69 System.out.println("************ 解析EXCEL失败 ************");
70 e.printStackTrace();
71 return null;
72 }
73 }
74 return reList;
75 }
76 }
输出:

五、遇到问题及解决
1、报错:

原因: 当导包不一致时会出现问题。

2.代码错误
1 int rowNum = sheet.getPhysicalNumberOfRows(); //获取行数
2 if (rowNum >1) {
3 Map<String, String> map = new HashMap<String, String>();//出现在错误的行,一个new,存储地址是一样的
4 for (int i = 1; i < rowNum; i++) {
5 Row row = sheet.getRow(i);
6 if (row!=null) {
7 // 第一列:省份
8 Cell cell0 = sheet.getRow(i).getCell(0);
9 if(cell0 != null && !"".equals(cell0)){
10 String Name =(String) cell0.getStringCellValue().trim();
11 map.put("name", Name);
12 }
13
14 reList.add(map);
15 }
16
17 }
18
19 }
错误结果:

如何实现批量上传----------Java解析excel的更多相关文章
- springboot实现上传并解析Excel
		添加pom依赖 <!-- excel解析包 --> <!-- https://mvnrepository.com/artifact/org.apache.poi/poi --> ... 
- 【转】上传并解析excel
		[转载自]http://blog.csdn.net/u011563331/article/details/51322523 通过解析excel,将数据存储到数据库中.现在将方法保存下来. 使用的是ap ... 
- java 文件上传与解析(excel,txt)
		excel上传与解析 https://blog.csdn.net/zsysu_it/article/details/79074067 txt解析 https://blog.csdn.net/CSDNw ... 
- 实现Excel文件的上传和解析
		前言 本文思维导图 一.需求描述 实现一个页面上传excel的功能,并对excel中的内容做解析,最后存储在数据库中. 二.代码实现 需求实现思路: 先对上传的文件做校验和解析,这里我们通过Excel ... 
- IT轮子系列(六)——Excel上传与解析,一套代码解决所有Excel业务上传,你Get到了吗
		前言 在日常开发当中,excel的上传与解析是很常见的.根据业务不同,解析的数据模型也都不一样.不同的数据模型也就需要不同的校验逻辑,这往往需要写多套的代码进行字段的检验,如必填项,数据格式.为了避免 ... 
- 使用phpExcel批量上传excel表数据到mysql数据库中
		/*批量上传数据*/ if(isset($_POST['submit']) && $_POST['submit']=='上传文件') { //导入类文件 require_once (& ... 
- Java Miniui实现批量上传文件demo 201906221520
		可能需要的jar包: 需要miniui(类似easyui). Test2019062201.jsp <%@ page language="java" contentType= ... 
- jquery文件批量上传控件Uploadify3.2(java springMVC)
		人比較懒 有用为主 不怎么排版了 先放上Uploadify的官网链接:http://www.uploadify.com/ -->里面能够看到PHP的演示样例,属性说明,以及控件下载地址.分f ... 
- [Pulgin] 利用swfupload实现java文件批量上传
		URL:http://blog.csdn.net/xuweilinjijis/article/details/8876305 之前在网上找过很多相关资料,很多所谓的批量上传都是忽悠人的,真正的批量上传 ... 
随机推荐
- Pandas应用案例-股票分析:使用tushare包获取股票的历史行情数据进行数据分析
			目标: 使用tushare包获取股票的历史行情数据 输出该股票所有收盘比开盘上涨3%以上的日期 输出该股票所有开盘比前日收盘跌幅超过2%以上的日期 假如为我们从2010年1月1日开始,每月第一个交易日 ... 
- SVM 支持向量机算法-原理篇
			公号:码农充电站pro 主页:https://codeshellme.github.io 本篇来介绍SVM 算法,它的英文全称是 Support Vector Machine,中文翻译为支持向量机. ... 
- 腾讯云COS对象存储占据数据容灾C位
			说到公有云容灾,大家首先想到的是云上数据备份. 然而,随着企业核心业务逐渐从线下迁移到云上,客户提出了更高的要求.如何确保云上业务的高可用.数据的高可靠,这对云厂商提出了新的挑战. 腾讯云作为全球领先 ... 
- 全网最全!彻底弄透Java处理GMT/UTC日期时间
			目录 前言 本文提纲 版本约定 正文 Date类型实现 时区/偏移量TimeZone 设置默认时区 让人恼火的夏令时 Date时区无关性 读取字符串为Date类型 SimpleDateFormat格式 ... 
- Hadoop2.7.7阿里云安装部署
			阿里云的网络环境不需要我们配置,如果是在自己电脑上的虚拟机,虚拟机的安装步骤可以百度.这里是单机版的安装(也有集群模式的介绍)使用Xshell连接阿里云主机,用命令将自己下载好的安装包上传到服务器 # ... 
- 特斯拉Toolbox诊断检测仪工具Tesla诊断电脑 Tesla Toolbox
			Tesla特斯拉Toolbox诊断工具Tesla诊断电脑检测仪 Tesla Toolbox, Tesla Toolbox Diagnostic Tester.Language: English,Deu ... 
- OpenCV 和 Dlib 人脸识别基础
			00 环境配置 Anaconda 安装 1 下载 https://repo.anaconda.com/archive/ 考虑到兼容性问题,推荐下载Anaconda3-5.2.0版本. 2 安装 3 测 ... 
- 免费稳定图床最佳实践:PicGo+GitHub+jsDeliver 极简教程
			一.下载 PicGo PicGo 是啥?顾名思义,它是一个快速上传图片并获取 图片 URL 链接的工具. 目前支持七牛.腾讯云.阿里云和 GitHub 等图床.该工具代码已在 GitHub 开源,读者 ... 
- 关掉IE提示“当前安全设置会使计算机有风险”
			我们先来看一下IE浏览器出现的提示窗口,该窗口位于最顶端,不点击设置的话,无法进行下一步的操作. 这时我们点击开始按钮 ,在弹出菜单中选择"运行"菜单项. 在打开的Windows运 ... 
- 获取当前文件路径  import 原理  一般把模块组成的集合称为包(package)
			获取当前文件路径 testpath.py import sysprint(sys.path) [root@d mapReduceLog]# python testpath.py['/data/mapR ... 
