一、引子

在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的更多相关文章

  1. springboot实现上传并解析Excel

    添加pom依赖 <!-- excel解析包 --> <!-- https://mvnrepository.com/artifact/org.apache.poi/poi --> ...

  2. 【转】上传并解析excel

    [转载自]http://blog.csdn.net/u011563331/article/details/51322523 通过解析excel,将数据存储到数据库中.现在将方法保存下来. 使用的是ap ...

  3. java 文件上传与解析(excel,txt)

    excel上传与解析 https://blog.csdn.net/zsysu_it/article/details/79074067 txt解析 https://blog.csdn.net/CSDNw ...

  4. 实现Excel文件的上传和解析

    前言 本文思维导图 一.需求描述 实现一个页面上传excel的功能,并对excel中的内容做解析,最后存储在数据库中. 二.代码实现 需求实现思路: 先对上传的文件做校验和解析,这里我们通过Excel ...

  5. IT轮子系列(六)——Excel上传与解析,一套代码解决所有Excel业务上传,你Get到了吗

    前言 在日常开发当中,excel的上传与解析是很常见的.根据业务不同,解析的数据模型也都不一样.不同的数据模型也就需要不同的校验逻辑,这往往需要写多套的代码进行字段的检验,如必填项,数据格式.为了避免 ...

  6. 使用phpExcel批量上传excel表数据到mysql数据库中

    /*批量上传数据*/ if(isset($_POST['submit']) && $_POST['submit']=='上传文件') { //导入类文件 require_once (& ...

  7. Java Miniui实现批量上传文件demo 201906221520

    可能需要的jar包: 需要miniui(类似easyui). Test2019062201.jsp <%@ page language="java" contentType= ...

  8. jquery文件批量上传控件Uploadify3.2(java springMVC)

    人比較懒  有用为主 不怎么排版了 先放上Uploadify的官网链接:http://www.uploadify.com/  -->里面能够看到PHP的演示样例,属性说明,以及控件下载地址.分f ...

  9. [Pulgin] 利用swfupload实现java文件批量上传

    URL:http://blog.csdn.net/xuweilinjijis/article/details/8876305 之前在网上找过很多相关资料,很多所谓的批量上传都是忽悠人的,真正的批量上传 ...

随机推荐

  1. Pandas应用案例-股票分析:使用tushare包获取股票的历史行情数据进行数据分析

    目标: 使用tushare包获取股票的历史行情数据 输出该股票所有收盘比开盘上涨3%以上的日期 输出该股票所有开盘比前日收盘跌幅超过2%以上的日期 假如为我们从2010年1月1日开始,每月第一个交易日 ...

  2. SVM 支持向量机算法-原理篇

    公号:码农充电站pro 主页:https://codeshellme.github.io 本篇来介绍SVM 算法,它的英文全称是 Support Vector Machine,中文翻译为支持向量机. ...

  3. 腾讯云COS对象存储占据数据容灾C位

    说到公有云容灾,大家首先想到的是云上数据备份. 然而,随着企业核心业务逐渐从线下迁移到云上,客户提出了更高的要求.如何确保云上业务的高可用.数据的高可靠,这对云厂商提出了新的挑战. 腾讯云作为全球领先 ...

  4. 全网最全!彻底弄透Java处理GMT/UTC日期时间

    目录 前言 本文提纲 版本约定 正文 Date类型实现 时区/偏移量TimeZone 设置默认时区 让人恼火的夏令时 Date时区无关性 读取字符串为Date类型 SimpleDateFormat格式 ...

  5. Hadoop2.7.7阿里云安装部署

    阿里云的网络环境不需要我们配置,如果是在自己电脑上的虚拟机,虚拟机的安装步骤可以百度.这里是单机版的安装(也有集群模式的介绍)使用Xshell连接阿里云主机,用命令将自己下载好的安装包上传到服务器 # ...

  6. 特斯拉Toolbox诊断检测仪工具Tesla诊断电脑 Tesla Toolbox

    Tesla特斯拉Toolbox诊断工具Tesla诊断电脑检测仪 Tesla Toolbox, Tesla Toolbox Diagnostic Tester.Language: English,Deu ...

  7. OpenCV 和 Dlib 人脸识别基础

    00 环境配置 Anaconda 安装 1 下载 https://repo.anaconda.com/archive/ 考虑到兼容性问题,推荐下载Anaconda3-5.2.0版本. 2 安装 3 测 ...

  8. 免费稳定图床最佳实践:PicGo+GitHub+jsDeliver 极简教程

    一.下载 PicGo PicGo 是啥?顾名思义,它是一个快速上传图片并获取 图片 URL 链接的工具. 目前支持七牛.腾讯云.阿里云和 GitHub 等图床.该工具代码已在 GitHub 开源,读者 ...

  9. 关掉IE提示“当前安全设置会使计算机有风险”

    我们先来看一下IE浏览器出现的提示窗口,该窗口位于最顶端,不点击设置的话,无法进行下一步的操作. 这时我们点击开始按钮 ,在弹出菜单中选择"运行"菜单项. 在打开的Windows运 ...

  10. 获取当前文件路径 import 原理 一般把模块组成的集合称为包(package)

    获取当前文件路径 testpath.py import sysprint(sys.path) [root@d mapReduceLog]# python testpath.py['/data/mapR ...