废话少说直接上代码,记得是poi3.8版本啊。方法入口唯一,自动判断格式,使用接口引用,自动选择执行方法。

方法入口:

public static ArrayList<String[]> explanExcelToList(String fileName) {
ArrayList<String[]> list = new ArrayList<String[]>();
Workbook wb = null;
try {
wb = get2003Workbook(new FileInputStream(fileName));
if (wb == null) {
wb = get2007Workbook(new FileInputStream(fileName));
if (wb == null) {
throw new RuntimeException("无法识别的格式,Unexpected Excel type (" + fileName + ")");
}
}
list = explanExcelToList(wb);

} catch (IOException e) {
e.printStackTrace();
}
return list;
}

package com.order.cc.outboundcall.impExlDate.svc;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date; import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.formula.eval.ErrorEval;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.DataFormatter;
import org.apache.poi.ss.usermodel.DateUtil;
import org.apache.poi.ss.usermodel.RichTextString;
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.xssf.usermodel.XSSFWorkbook;
import org.apache.struts.upload.FormFile; public class ExcelHelper {
private static Integer SHEET_PAGE_NUM = 0;// 读取sheet页第一页 public static ArrayList<String[]> explanExcelToList(String fileName) {
ArrayList<String[]> list = new ArrayList<String[]>();
Workbook wb = null;
try {
wb = get2003Workbook(new FileInputStream(fileName));
if (wb == null) {
wb = get2007Workbook(new FileInputStream(fileName));
if (wb == null) {
throw new RuntimeException("无法识别的格式,Unexpected Excel type (" + fileName + ")");
}
}
list = explanExcelToList(wb); } catch (IOException e) {
e.printStackTrace();
}
return list;
} public static ArrayList<String[]> explanExcelToList(Workbook wb) {
ArrayList<String[]> resList = new ArrayList<String[]>();
if (wb == null) {
return resList;
}
try {
wb.setMissingCellPolicy(Row.RETURN_BLANK_AS_NULL);// 空白设置为null
// 读取第一章表格内容
Sheet sheet = wb.getSheetAt(SHEET_PAGE_NUM);
if (sheet == null) {
return resList;
}
// 循环输出表格中的内容
resList = explantSheet(sheet);
} catch (Exception e) {
e.printStackTrace();
}
return resList;
} /**
*
* 功能说明 使用接口解析Sheet,支持HSSFSheet 与XSSFSheet格式
*
* @创建人 yxh
* @时间 2016-4-26
* @参数说明 @param list
* @参数说明 @param sheet
* @参数返回说明 void
*/
public static ArrayList<String[]> explantSheet(Sheet sheet) {
ArrayList<String[]> list = new ArrayList<String[]>();
if (sheet == null) {
return list;
}
int rowNum = sheet.getRow(0) != null ? sheet.getRow(0).getPhysicalNumberOfCells() : 0;// 通过表头定义数组的位数,确定每行固定大小
if (rowNum == 0) {
rowNum = sheet.getRow(1) != null ? sheet.getRow(1).getPhysicalNumberOfCells() : 0;// 防止不写表头
}
for (int i = 0; i < sheet.getPhysicalNumberOfRows(); i++) {// 循环行
Row row = sheet.getRow(i);
if (row == null) {
continue;
}
String[] contentArr = new String[rowNum];
for (int j = 0; j < rowNum; j++) {// 循环列
Cell cell = row.getCell(j);
String text = "";
if (cell != null) {
text = formatCell(cell);
}
contentArr[j] = text;
}
list.add(contentArr);
}
return list;
} /**
*
* 功能说明 格式化表格内容
*
* @创建人 yxh
* @时间 2016-4-26
* @参数说明 @param cell
* @参数说明 @return
* @参数返回说明 String
*/
public static String formatCell(Cell cell) {
DataFormatter _formatter = new DataFormatter();
switch (cell.getCellType()) {
case Cell.CELL_TYPE_STRING: // 2016年4月27日11:19:20 在excel中视为字符串形式
return cell.getRichStringCellValue().getString();
case Cell.CELL_TYPE_NUMERIC:// 数值型
if (DateUtil.isCellDateFormatted(cell)) {// 日期 poi
return dateToString(cell.getDateCellValue());
} else {
return _formatter.formatCellValue(cell);
}
case Cell.CELL_TYPE_BOOLEAN:
return cell.getBooleanCellValue() == true ? "true" : "false";// boolean
// 转成String
case Cell.CELL_TYPE_ERROR:
return ErrorEval.getText(cell.getErrorCellValue());// 返回错误码
case Cell.CELL_TYPE_FORMULA:// 公式
switch (cell.getCachedFormulaResultType()) {
case Cell.CELL_TYPE_STRING:
RichTextString str = cell.getRichStringCellValue();
if (str != null && str.length() > 0) {
return str.toString();
}
case Cell.CELL_TYPE_NUMERIC:
CellStyle style = cell.getCellStyle();
if (style == null) {
return cell.getNumericCellValue() + "";// double转成String
} else {
return _formatter.formatRawCellContents(cell.getNumericCellValue(), style.getDataFormat(), style.getDataFormatString());
}
case Cell.CELL_TYPE_BOOLEAN:
return cell.getBooleanCellValue() ? "true" : "false";// boolean
// 转成String
case Cell.CELL_TYPE_ERROR:
return ErrorEval.getText(cell.getErrorCellValue()); }
default:
throw new RuntimeException("Unexpected cell type (" + cell.getCellType() + ")");
}
} public static String dateToString(Date date) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
return sdf.format(date);
} public static String dateToString(String date) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
return sdf.format(date);
} public static void closeFile(FormFile file) {
if (file != null) {
try {
file.destroy();
} catch (Exception e2) {
e2.printStackTrace();
}
}
} public static Workbook get2003Workbook(InputStream is) {
Workbook wb = null;
try {
wb = new HSSFWorkbook(is);
} catch (Exception e) {
return wb;
}
return wb;
} public static Workbook get2007Workbook(InputStream is) {
Workbook wb = null;
try {
wb = new XSSFWorkbook(is);
} catch (Exception e) {
return wb;
}
return wb;
} public static boolean isExcel2003(InputStream is) {
try {
new HSSFWorkbook(is);
} catch (Exception e) {
return false;
}
return true;
} public static boolean isExcel2007(InputStream is) {
try {
new XSSFWorkbook(is);
} catch (Exception e) {
return false;
}
return true;
} public static void main(String[] args) {
// FormFile file=null;
// explanExcelToList(file);
}
}

POI 3.8读取2003与2007格式EXCEL(xls、xlsx)的更多相关文章

  1. JAVA用POI读取和创建2003和2007版本Excel

    1.添加maven依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-o ...

  2. JAVA用POI读取和创建2003和2007版本Excel完美示例

    import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...

  3. C#中npoi操作Excel[版本2.0.1读写2003、2007格式]

    下载npoi2.0.1dll文件:http://download.csdn.net/detail/pukuimin1226/5851747 public static void test1()     ...

  4. PHPExcel 导出2003和2007的excel文档实例

    require_once 'common/excel/PHPExcel.php'; require_once 'common/excel/phpExcel/Writer/Excel2007.php'; ...

  5. python读取excel数据为json格式(兼容xls\xlsx)

    做自动化时需要从excel读取数据: 本文实现将excel文件数据读取为json格式,方便自动化调用 读取xls文件 使用xlrd读取xls文件代码: import xlrd def read_xls ...

  6. java使用poi.3.10读取excel 2007以上版本(xlsx格式)

    1.在使用过程中,一直报错 throw new ClassNotFoundException(name);原因:没有导入xmlbeans-2.6.0.jar包,建议在使用poi时,将所有包都导入进工程 ...

  7. NPOI 2.1.1 系列(1) 使用NPOI读取 Excel文档 ;NpoiExcelHelper 导入导出 2003格式 2007格式的 Excel; Npoi 导出 xlsx 格式

    下载地址 http://npoi.codeplex.com/releases 下面放一个 NPOIHelper 助手类吧,也不是我写的- NpoiExcelHelper 可以生成xlsx格式publi ...

  8. java 使用POI读写Excel文件(兼容2003、2007)

    package com.jadyer.demo; import java.io.File; import java.io.FileOutputStream; import java.io.IOExce ...

  9. 转帖 java使用poi.3.10读取excel 2010

    package poi; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; ...

随机推荐

  1. SDOI Day2

    今天做了SDOI Day2 觉得自己萌萌哒= =题目真的有点水,一点编程复杂度都没有 T1:星际战争 描述:http://www.lydsy.com/JudgeOnline/problem.php?i ...

  2. ShiWangMeSDK Android版接口文档 0.2.0 版

    # ShiWangMeSDK Android版接口文档 0.2.0 版 android 总共有 14 个接口,分别涉及到初始化和对界面的一些细节的控制.下面详细介绍接口,如果没有特殊说明,接口都在 S ...

  3. NSKeyedArchiver/NSKeyedUnarchiver归档应用(缓存实现)

    NSKeyedUnarchiver : 从二进制流读取对象; NSKeyedArchiver :把对象写到二进制流中去. 要实现对数据模型的归档,需要我们实现NScoding协议,(NScoping) ...

  4. canvas绘图不清晰的解决方案

    现象描述 同样大小的图片(60x60px)用canvas和DOM绘制,结果发现canvas的画面质量要差很多.结果如下图所示. 上图中,左侧红框中的金币采用DOM绘制,右侧和下方的金币和文字等使用ca ...

  5. 架构师之路——里氏替换原则LSP

    定义: 如果对每一个对类型为S的对象o1,都有类型为T的对象o2,使得以T定义的所有程序P在所有的对象o1都代换成o2时,程序P的行为没有发生变化,那么类型S是类型T的子类型. 内容: 里氏替换原则通 ...

  6. chrome浏览器美化插件:让你的浏览器页面冒水泡, 游小鱼儿

    下载插件和效果图 这是一个让你的浏览器冒泡泡的插件, 浏览网页的时候仿佛置身于海底世界: 插件下载地址:http://files.cnblogs.com/files/diligenceday/chro ...

  7. dedecms织梦自定义表单提交之后如何发送到邮箱!

    但是往往一些客户需要做一些提交信息到后台并发送到指定的邮箱. 一.直接打开plus下面的diy.php文件:  85行:$query = "INSERT INTO `{$diy->ta ...

  8. GridView应用随笔

    1. 数据绑定 GridView可以使用数据源控件和设置控件的DataSource属性来绑定数据,这里主要讲设置DataSource属性来绑定. 1.写一个返回值为DataSet或者DataTable ...

  9. (@WhiteTaken)UGUI中遇到的一些细碎的知识点

    最近接触Unity中UGUI的知识比较多,遇到的东西,就慢慢积累下来吧.用到就不用去网上找了. 1.Unity加载Sprite图片资源.在Unity中,我们可能会遇到,一张图片中,有多个UI,这时候导 ...

  10. gridview中后台获取某列的值

    下面的gridview中,获取某行某列的值(非模板页),如图所示 <asp:GridView AutoGenerateColumns="false" CssClass=&qu ...