由于在项目中使用了将excel数据导入到数据库。在这里分享一下。

这里使用的POI方式,支持两种格式(xls,xlsx)

package com.entity;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
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.ss.usermodel.WorkbookFactory;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.XSSFWorkbook; /**
* excel公共方法
*/
public final class ExcelUtil { private ExcelUtil() { } // 读取excel的结果集
private static ArrayList<Map<String, String>> result = null; // 记录表格中空行的行数
private static int num = 0; private static List<String> numList = new ArrayList<String>(); /**
* 获取需要传入数据库的数据
*/
public static void readExcelData(final String filePath) {
try {
readExcelToObj(filePath);
} catch (Exception e) {
System.out.println("导入失败");
}
} /**
* 读取excel数据
*/
private static ArrayList<Map<String, String>> readExcelToObj(final String path) throws Exception {
Workbook wb = null;
result = new ArrayList<Map<String, String>>();
try {
wb = WorkbookFactory.create(new File(path));
Sheet sheet = wb.getSheetAt(0);
result = readExcel(wb, sheet, 0, 0);
} catch (InvalidFormatException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return result;
} /**
* 读取excel文件
* @param sheet sheet页下标:从0开始
* @param startReadLine 开始读取的行:从0开始
* @param tailLine 去除最后读取的行
*/
private static ArrayList<Map<String, String>> readExcel(final Workbook wb, final Sheet sheet, final int startReadLine, final int tailLine) {
Row row = null;
for (int i = startReadLine; i < sheet.getLastRowNum() - tailLine + 1; i++) {
row = sheet.getRow(i);
Map<String, String> map = new HashMap<String, String>();
for (Cell c : row) {
String returnStr = "";
boolean isMerge = isMergedRegion(sheet, i, c.getColumnIndex());
//判断是否具有合并单元格
if (isMerge) {
String rs = getMergedRegionValue(sheet, row.getRowNum(), c.getColumnIndex());
returnStr = rs;
} else {
returnStr = c.getRichStringCellValue().getString();
} if (c.getColumnIndex() == 0) {
map.put("id", returnStr);
} else if (c.getColumnIndex() == 1) {
map.put("railwayTripsIn", returnStr);
} else if (c.getColumnIndex() == 2) {
map.put("arriveTime", returnStr);
} else if (c.getColumnIndex() == 3) {
map.put("railwayNum", returnStr);
} else if (c.getColumnIndex() == 4) {
map.put("checkTrack", returnStr);
} else if (c.getColumnIndex() == 5) {
map.put("maintenanceTask", returnStr);
} else if (c.getColumnIndex() == 6) {
map.put("maintenanceUnitName", returnStr);
} else if (c.getColumnIndex() == 7) {
map.put("project", returnStr);
} else if (c.getColumnIndex() == 8) {
map.put("startTime", returnStr);
} else if (c.getColumnIndex() == 9) {
map.put("finishTime", returnStr);
} else if (c.getColumnIndex() == 10) {
map.put("linkTrack", returnStr);
} else if (c.getColumnIndex() == 11) {
map.put("outboundTime", returnStr);
} else if (c.getColumnIndex() == 12) {
map.put("railwayTripsOut", returnStr);
}
}
result.add(map);
}
return result;
} public static List<TrackData> splitCenterData(ArrayList<Map<String,String>> result) throws Exception {
trackListData = new ArrayList<TrackData>();
Map<String,String> map = new HashMap<String,String>();
Integer lineNumDataSize = result.size() - 5;
for (int i = 0; i < lineNumDataSize; i++) {
trackData = new TrackData();
map = result.get(i);
trackData.setId(map.get("id").trim());
trackData.setInTimes(map.get("inTimes").trim());
if(map.get("inTime").toString().trim().equals("\\")) {
trackData.setInTime(null);
} else {
trackData.setInTime(map.get("inTime"));
}
trackData.setCarGroud(map.get("carGroud").trim());
trackData.setCheckTrack(map.get("checkTrack").trim());
trackData.setJob(map.get("job").trim());
trackData.setNewsSource(map.get("newsSource").trim());
trackData.setProject(map.get("project").trim());
trackData.setStartTime(map.get("startTime").trim());
trackData.setEndTime(map.get("endTime").trim());
if(map.get("linkTrack").toString().trim().equals("\\")) {
trackData.setLinkTrack(null);
} else {
trackData.setLinkTrack(map.get("linkTrack").trim());
}
if(map.get("outTime").toString().trim().equals("\\")) {
trackData.setOutTime(null);
} else {
trackData.setOutTime(map.get("outTime").trim());
}
if(map.get("outTimes").toString().trim().equals("\\")) {
trackData.setOutTimes(null);
} else {
trackData.setOutTimes(map.get("outTimes").trim());
}
trackListData.add(trackData);
}
return trackListData;
} /**
* 获取合并单元格的值
* @param sheet
* @param row
* @param column
*/
private static String getMergedRegionValue(final Sheet sheet, final int row, final int column) {
int sheetMergeCount = sheet.getNumMergedRegions(); for (int i = 0; i < sheetMergeCount; i++) {
CellRangeAddress ca = sheet.getMergedRegion(i);
int firstColumn = ca.getFirstColumn();
int lastColumn = ca.getLastColumn();
int firstRow = ca.getFirstRow();
int lastRow = ca.getLastRow(); if (row >= firstRow && row <= lastRow) { if (column >= firstColumn && column <= lastColumn) {
Row fRow = sheet.getRow(firstRow);
Cell fCell = fRow.getCell(firstColumn);
return getCellValue(fCell);
}
}
} return null;
} /**
* 判断合并了行
* @param sheet
* @param row
* @param column
*/
private static boolean isMergedRow(final Sheet sheet, final int row, final int column) {
int sheetMergeCount = sheet.getNumMergedRegions();
for (int i = 0; i < sheetMergeCount; i++) {
CellRangeAddress range = sheet.getMergedRegion(i);
int firstColumn = range.getFirstColumn();
int lastColumn = range.getLastColumn();
int firstRow = range.getFirstRow();
int lastRow = range.getLastRow();
if (row == firstRow && row == lastRow) {
if (column >= firstColumn && column <= lastColumn) {
return true;
}
}
}
return false;
} /**
* 判断指定的单元格是否是合并单元格
* @param sheet
* @param row 行下标
* @param column 列下标
*/
private static boolean isMergedRegion(final Sheet sheet, final int row, final int column) {
int sheetMergeCount = sheet.getNumMergedRegions();
for (int i = 0; i < sheetMergeCount; i++) {
CellRangeAddress range = sheet.getMergedRegion(i);
int firstColumn = range.getFirstColumn();
int lastColumn = range.getLastColumn();
int firstRow = range.getFirstRow();
int lastRow = range.getLastRow();
if (row >= firstRow && row <= lastRow) {
if (column >= firstColumn && column <= lastColumn) {
return true;
}
}
}
return false;
} /**
* 判断sheet页中是否含有合并单元格
* @param sheet
*/
private static boolean hasMerged(final Sheet sheet) {
return sheet.getNumMergedRegions() > 0 ? true : false;
} /**
* 合并单元格
* @param sheet
* @param firstRow 开始行
* @param lastRow 结束行
* @param firstCol 开始列
* @param lastCol 结束列
*/
private static void mergeRegion(final Sheet sheet, final int firstRow, final int lastRow, final int firstCol, final int lastCol) {
sheet.addMergedRegion(new CellRangeAddress(firstRow, lastRow, firstCol, lastCol));
} /**
* 获取单元格的值
* @param cell
* @return
*/
private static String getCellValue(final Cell cell) { if (cell == null) {
return "";
} if (cell.getCellType() == Cell.CELL_TYPE_STRING) {
return cell.getStringCellValue();
} else if (cell.getCellType() == Cell.CELL_TYPE_BOOLEAN) {
return String.valueOf(cell.getBooleanCellValue());
} else if (cell.getCellType() == Cell.CELL_TYPE_FORMULA) {
return cell.getCellFormula();
} else if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {
return String.valueOf(cell.getNumericCellValue());
}
return "";
} /**
* 判断行为空 lineNum 为空行的开始位置
*/
private static Integer checkRowNull(final Sheet sheet, final int rows) {
Row row = null;
for (int i = 0; i < rows; i++) {
int cols = sheet.getRow(i).getPhysicalNumberOfCells();
int col = 0;
row = sheet.getRow(i);
for (Cell c : row) {
String returnStr = "";
boolean isMerge = isMergedRegion(sheet, i, c.getColumnIndex());
// 判断是否具有合并单元格
if (isMerge) {
String rs = getMergedRegionValue(sheet, row.getRowNum(), c.getColumnIndex());
returnStr = rs;
} else {
returnStr = c.getRichStringCellValue().getString();
}
if (returnStr.trim() == null || returnStr.trim() == "") {
col++;
}
}
if (cols == col) {
num++;
}
}
return num;
} /**
* 从excel读取内容
*/
private static void readContent(final String fileName) {
boolean isE2007 = false; //判断是否是excel2007格式
if (fileName.endsWith("xlsx")) {
isE2007 = true;
}
try {
InputStream input = new FileInputStream(fileName); //建立输入流
Workbook wb = null;
//根据文件格式(2003或者2007)来初始化
if (isE2007) {
wb = new XSSFWorkbook(input);
} else {
wb = new HSSFWorkbook(input);
}
Sheet sheet = wb.getSheetAt(0); //获得第一个表单
Iterator<Row> rows = sheet.rowIterator(); //获得第一个表单的迭代器
while (rows.hasNext()) {
Row row = rows.next(); //获得行数据
System.out.println("Row #" + row.getRowNum()); //获得行号从0开始
Iterator<Cell> cells = row.cellIterator(); //获得第一行的迭代器
while (cells.hasNext()) {
Cell cell = cells.next();
System.out.println("Cell #" + cell.getColumnIndex());
switch (cell.getCellType()) { //根据cell中的类型来输出数据
case HSSFCell.CELL_TYPE_NUMERIC:
System.out.println(cell.getNumericCellValue());
break;
case HSSFCell.CELL_TYPE_STRING:
System.out.println(cell.getStringCellValue());
break;
case HSSFCell.CELL_TYPE_BOOLEAN:
System.out.println(cell.getBooleanCellValue());
break;
case HSSFCell.CELL_TYPE_FORMULA:
System.out.println(cell.getCellFormula());
break;
default:
System.out.println("unsuported sell type=======" + cell.getCellType());
break;
}
}
}
} catch (IOException ex) {
ex.printStackTrace();
}
}
}

  

Java操作excel(POI)的更多相关文章

  1. Java操作Excel: POI不能创建xlsm问题的方法(源自StackOverFlow)

    write to xlsm (Excel 2007) using apache poi POI的下载(记得把其中的jar包全部加到工程里哦)http://mirror.bit.edu.cn/apach ...

  2. java操作Excel处理数字类型的精度损失问题验证

    java操作Excel处理数字类型的精度损失问题验证: 场景: CELL_TYPE_NUMERIC-->CELL_TYPE_STRING--->CELL_TYPE_NUMERIC POI版 ...

  3. java操作Excel、PDF文件

    java操作Excel.PDF文件 分享者:Vashon 分享来源:CSDN博客 下面这些是在开发中用到的一些东西,有的代码贴的不是完整的,只是贴出了关于操作EXCEL的代码: jxl是一个*国人写的 ...

  4. java操作excel 工具类

    java操作excel 可参考https://blog.csdn.net/xunwei0303/article/details/53213130 直接上代码: 一.java生成excel文件: pac ...

  5. Java 操作 EXCEL

    今天帮朋友写了一段用来处理EXCEL内容的程序,在这里记录下自己的学习过程.主要是对EXCEL表格中的内容做分类和统计,使用计算机来做这种重复的机械性地工作再好不过了.首先,我们需要下载一个java操 ...

  6. JAVA操作Excel时文字自适应单元格的宽度设置方法

    使用JAVA操作Excel通常都使用JXL,方法很简单网上也有很多的教程,然后往往一些细节性的问题却导致我们这些Programmer苦恼不已.这两天帮一个朋友做一个Excel表格自动生成的小软件,就遇 ...

  7. jxl的使用总结(java操作excel)

    jxl.jar是通过java操作excel表格的工具类库: jxl.jar包:链接:http://pan.baidu.com/s/1o8qFJHw 密码:5jyq 1:通过模拟实现创建一个表格,然后模 ...

  8. Java操作Excel文件以及在Android中的应用

    本文章由临江仙原创,转载请注明出处:http://blog.csdn.net/zhy_cheng/article/details/10286563 Excel作为一种有格式的文件,可以使用Java来对 ...

  9. 【转载】jxl的使用总结(java操作excel)

    jxl.jar是通过java操作excel表格的工具类库: 链接:https://pan.baidu.com/s/1AAT_eA_Q47zFeQohap6eQg 提取码:777b 1:通过模拟实现创建 ...

  10. java操作excel总结---poi

    前不久做过Excel的导入导出功能,其主要的难点是java如何操作Excel文档.现在就来介绍一下利用Apache的poi如何操作Excel. 1.准备工作:导入Apache POI的相关jar包,P ...

随机推荐

  1. thinkphp5登录并保存session、根据不同用户权限跳转不同页面

    本文讲述如何在thinkphp5中完成登录并保存session.然后根据不同的用户权限跳转相应页面功能的实现.我也在学习thinkphp源码的路上,记录一下并与大家分享.完成该步骤主要有以下三个步骤完 ...

  2. Echarts简单图表

    一.实现要点 常用可视化图表库 Echarts HighCharts D3.js neo4j (NOSQL) 1.导入js库 <script type="text/javascript ...

  3. Spring学习(1):侵入式与非侵入式,轻量级与重量级

    一. 引言 在阅读spring相关资料,都会提到Spring是非侵入式编程模型,轻量级框架,那么就有必要了解下这些概念. 二. 侵入式与非侵入式 非侵入式:使用一个新的技术不会或者基本不改变原有代码结 ...

  4. 使用Mininet创建网络拓扑

    使用Mininet创建Topo Python脚本实现创建拓扑 #coding:utf-8 from mininet.net import Mininet from mininet.topo impor ...

  5. Testing Harbor REST API on Swagger

    先贴官方地址,我的做法差不多 https://github.com/goharbor/harbor/blob/master/docs/configure_swagger.md 1.下载对应资源 wge ...

  6. K-近邻算法入门

    K-近邻算法的直观理解就是:给定一个训练集合,对于新的实例,在训练集合中找到k个与该实例最近的邻居,然后根据“少数服从多数”原则判断该实例归属于哪一类,又称“随大流” K-近邻算法的三大要素:K值得选 ...

  7. linux-sftp-指定端口号登录远程主机

    sftp -oPort=60001 root@192.168.0.254 -o选项来指定端口号 -oPort=远程端口号

  8. “Hello World!”团队第三周召开的第三次会议

    今天是我们团队“Hello World!”团队第三周召开的第三次会议.博客内容: 一.会议时间 二.会议地点 三.会议成员 四.会议内容 五.todo list 六.会议照片 七.燃尽图 八.代码地址 ...

  9. Android开发设计 实验报告

    20162315 Android开发设计 实验报告 实验内容 1.安装 Android Stuidio,完成Hello World, 要求修改res目录中的内容,Hello World后要显示自己的学 ...

  10. YQCB冲刺周第二天

    YQCB冲刺周第二天 1.实现用户记账的功能 2.实现用户头像的设置 3.实现个人设置的功能 遇到的问题: 记账的分类,数据库存取图片,页面跳转+超链接的使用 团队讨论的照片:             ...