java使用poi.3.10读取excel 2007以上版本(xlsx格式)
2024-09-14 03:19:10
1、在使用过程中,一直报错 throw new ClassNotFoundException(name);原因:没有导入xmlbeans-2.6.0.jar包,建议在使用poi时,将所有包都导入进工程。
2、案例源码
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Iterator;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
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.xssf.usermodel.XSSFWorkbook;
import org.junit.Test; public class TestExcelS { public static String filePath = TestExcel.class.getResource("/test.xlsx").getPath();
@Test
public static void main(String[] args) {
readXml(filePath);
System.out.println("-------------");
}
public static void readXml(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");
break;
}
}
}
} catch (IOException ex) {
ex.printStackTrace();
}
}
}
相关代码注释可参考Java使用poi读取Excel2003
最新文章
- Nodejs 饭店
- jQuery实例
- qsort函数用法【转】
- 用PowerDesigner将SQL语句生成实体类
- uTenux&mdash;&mdash;HelloWord
- nginx反向代理原理和配置讲解
- 百度分享share.js插件
- 查找后去掉EditTextView的焦点
- [LeetCode]Copy List with Random Pointer &;amp;Clone Graph 复杂链表的复制&;amp;图的复制
- 悬挂else引发的问题
- react-native入坑随笔(持续更新中)
- iOS下JS与OC互相调用(四)--JavaScriptCore
- Kubernetes — 控制器
- 异步请求取得json数据
- confidence interval
- mssql 系统函数-字符串函数专题--字符串函数大全
- 《生命》第四集:Fish (鱼类)
- docker从容器里面拷文件到宿主机或从宿主机拷文件到docker容器里面
- U3D面试五
- 17-Python3 循环语句