如何使用java poi框架读取excel 2010实例源码介绍



如何使用用java poi框架读取excel 2010实例源码介绍。现在越来越多人使用excel 2010了,使用java作为编程语言的人难免会遇到如何实现java读取excel 的问题,以就为大家介绍解决这问题的方法,希望可以给您带来帮助!

首先你要下载 最新的 poi,java poi下载网址是:  http://poi.apache.org/download.html 

   

最新的java  poi下载地址,下载图片。

最新的java poi下载地址,下载图片。

第二步、解压下载到的文件,然后 把相关jar包引进java项目 ,其中excel 2010 用的是 XSSH 开头的相关包,相关的类在 名称包含OOXML的相关jar包里面。
用poi框架读取excel 2010相关jar包。

用poi框架读取excel 2010相关jar包。

3、下面是用java poi框架读取excel 2010实例源码
   
 import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
public class Excel2010Operation {
 
public static void main(String[] args) throws Exception {
// File file = new File(“src\\excelResourceFile\\privilege.xlsx”);
File file = new File(“src\\excelUserFile\\excelUserFile.xlsx”);
Excel2010Operation excel = new Excel2010Operation();
List> workBook = excel.getData(file,”all”, 0);
for (List sheet : workBook) {
 
for (String[] row : sheet) {
 
for (int col = 0; col < row.length; col++) {
System.out.print(row[col] + “\t”);
}
System.out.println();
}
System.out.println();
System.out.println(“……………… one sheet read end …………………………………”);
System.out.println();
}
}
 
 //ignoreRows 表示读取某个表时,忽略的行数。
public List> getData(File file,String privilegeType,int ignoreRows)
throws FileNotFoundException, IOException {
List> sheets = new ArrayList>();// 一个list存储一个工作簿
BufferedInputStream in = new BufferedInputStream(new FileInputStream(
file));
XSSFWorkbook workbook = new XSSFWorkbook(in);
// start read a sheet
sheets = this.getWorkBook(workbook, privilegeType, ignoreRows);
// end read a sheet
in.close();
return sheets;
}
// start 获取excle 一个 工作簿(workBook)的记录
public List> getWorkBook(XSSFWorkbook workbook,String privilegeType,
int ignoreRows) {
// 一个list存储一个工作簿
List> sheets = new ArrayList>();
for (int sheetIndex = 0; sheetIndex < workbook.getNumberOfSheets(); sheetIndex++) {
List result = new ArrayList();// 一个list存储一个sheet的所有行
XSSFSheet sheet = workbook.getSheetAt(sheetIndex);
String sheetName=sheet.getSheetName(); //获取sheet的名字
 
if(“ALL”.equalsIgnoreCase(privilegeType)){}
else if(!sheetName.equalsIgnoreCase(privilegeType) ){
continue;
}
//System.out.println(sheetName);
// 获取表格,ignoreRows为忽略的行数;
result = getExcelSheet(sheet, ignoreRows);
sheets.add(result);
}
return sheets;
}
// end 获取excle 一个 工作簿(workBook)的记录
// start 获取excle 一个表(sheet)的记录
public List getExcelSheet(XSSFSheet xssfSheet, int ignoreRows) {
XSSFSheet sheet = xssfSheet;
// 一个list存储一个workBook的所有行
List result = new ArrayList();
 
for (int rowIndex = ignoreRows; rowIndex <= sheet.getLastRowNum(); rowIndex++) {
XSSFRow row = sheet.getRow(rowIndex);
if (row == null) {
                 continue;
                 }
 
String values[] = getExcelRole(row);
result.add(values);
}
return result;
}
// end 获取excle 一个表(sheet)的记录
// start 获取excle 一行的记录
public String[] getExcelRole(XSSFRow xSSFRow) {
XSSFRow row = xSSFRow;
int rowSize = 0;
XSSFCell cell = null;
if (row == null) {
            System.out.println(“空空”);
return null;
}
int tempRowSize = row.getLastCellNum() + 1;// 获取列数
if (tempRowSize > rowSize) {
rowSize = tempRowSize;// 获取列数
}
String[] values = new String[rowSize];// values store a row ‘s all
// column value;
Arrays.fill(values, “”);
boolean hasValue = false;
// start all column for a row
for (short columnIndex = 0; columnIndex <= row.getLastCellNum(); columnIndex++) {
String value = “”;
cell = row.getCell(columnIndex);
if (cell != null) {
// 注意:一定要设成这个,否则可能会出现乱码
// cell.setEncoding(HSSFCell.ENCODING_UTF_16);
switch (cell.getCellType()) {
case XSSFCell.CELL_TYPE_STRING:
value = cell.getStringCellValue();
break;
case XSSFCell.CELL_TYPE_NUMERIC:
if (HSSFDateUtil.isCellDateFormatted(cell)) {
Date date = cell.getDateCellValue();
if (date != null) {
value = new SimpleDateFormat(“yyyy-MM-dd”)
.format(date);
} else {
value = “”;
}
} else {
value = new DecimalFormat(“0″).format(cell
.getNumericCellValue());
}
break;
case XSSFCell.CELL_TYPE_FORMULA:
// 导入时如果为公式生成的数据则无值
if (!cell.getStringCellValue().equals(“”)) {
value = cell.getStringCellValue();
} else {
value = cell.getNumericCellValue() + “”;
}
break;
case XSSFCell.CELL_TYPE_BLANK:
break;
case XSSFCell.CELL_TYPE_ERROR:
value = “”;
break;
case XSSFCell.CELL_TYPE_BOOLEAN:
value = (cell.getBooleanCellValue() == true ? “Y”
: “N”);
break;
default:
value = “”;
}
}
if (columnIndex == 0 && value.trim().equals(“”)) {
break;
}
values[columnIndex] = this.rightTrim(value);
hasValue = true;
}
return values;
}
// end 获取excle 一行的记录
public String rightTrim(String str) {
if (str == null) {
return “”;
}
int length = str.length();
for (int i = length – 1; i >= 0; i–) {
if (str.charAt(i) != 0×20) {
break;
}
length–;
}
return str.substring(0, length);
}
     也许有些朋友看到以上使用java poi框架读取excel 2010实例源码会感到疑惑,其实只要你真的实践后你会明白的,请你好好试一试,多多思考。