java 用poi框架读取excel 2010
来源:互联网 发布:mac ps 序列号 编辑:程序博客网 时间:2024/06/16 22:25
1、下载 最新的 poi http://poi.apache.org/download.html
import java.io.BufferedInputStream;
//ignoreRows 表示读取某个表时,忽略的行数。
continue; }
System.out.println("空空");
2、解压 把相关jar包引进项目 ,excel 2010 用的是 XSSH 开头的相关包,相关的类在 名称包含OOXML的相关jar包内。
3、下面是一个简单的例子
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();
}
}
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) {
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) {
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) != 0x20) {
break;
}
length--;
}
return str.substring(0, length);
}
}
0 0
- java 用poi框架读取excel 2010
- Java用poi读取excel
- Java POI 读取Excel
- java poi读取excel
- java Excel 读取 poi
- Java POI 读取Excel
- java poi读取excel
- java poi 读取Excel
- java poi 读取excel
- Java读取Excel:POI
- java poi 读取Excel
- Java POI Excel读取
- java使用poi.3.10读取excel 2010
- java POI读取Excel 2003/2007/2010
- Java用poi读取excel文件
- Java用poi读取excel文件
- java利用poi读取excel
- java poi 读取Excel demo
- 一篇文章普及各种ios基本知识(防止奸商忽悠、鉴别假冒翻新机、知识入门必备)
- 清水设计表现~~~专业承接家装,工装效果图制作~~~
- C语言中,栈的操作
- 尤尼科技首推3D打印机使用教材 助力3D打印基础教育产业
- java socket单线程阻塞IO
- java 用poi框架读取excel 2010
- spring拦截器配置
- 网络基于NGN/IMS(SIP协议)通信平台融入视频监控业务
- 基本社会里模型的源码分析
- 全角字符unicode码对应表
- 基于Virtex系列FPGA的可编程嵌入式信号处理背板的设计
- 24_C# 实现VMS客户端——控件_布局设计
- ADI 15款常用的运算放大器的对比学习
- JS数组方法汇总 array数组元素的添加和删除