關於Java讀取Excel2007的文章在Google、百度上搜索一下,沒有太好的例子,實現的也不算太好。查看了一下Poi,最新的 POI 3.5 beta 4 支持讀寫 Excel2007和PPT2007(XLSX and PPTX),自己來實現Java讀取Excel2007了。
1,下載 POI 3.5 beta 4 解壓,把其中的jar包導入項目文件。以我的讀取爲例,導入了以下jar包。
沒有配置 log4j,測試時報告警報信息,應該爲加載順序導致的初始化問題造成(暫時沒有找原因)。
2,建立讀取 Excel2007 方法
- // 構造 XSSFWorkbook 對象,strPath 傳入文件路徑
- XSSFWorkbook xwb = new XSSFWorkbook(strPath);
- // 讀取第一章表格內容
- XSSFSheet sheet = xwb.getSheetAt(0);
- // 定義 row、cell
- XSSFRow row;
- String cell;
- // 循環輸出表格中的內容
- for (int i = sheet.getFirstRowNum(); i < sheet.getPhysicalNumberOfRows(); i++) {
- row = sheet.getRow(i);
- for (int j = row.getFirstCellNum(); j < row.getPhysicalNumberOfCells(); j++) {
- // 通過 row.getCell(j).toString() 獲取單元格內容,
- cell = row.getCell(j).toString();
- System.out.print(cell + "/t");
- }
- System.out.println("");
- }
// 構造 XSSFWorkbook 對象,strPath 傳入文件路徑
XSSFWorkbook xwb = new XSSFWorkbook(strPath);
// 讀取第一章表格內容
XSSFSheet sheet = xwb.getSheetAt(0);
// 定義 row、cell
XSSFRow row;
String cell;
// 循環輸出表格中的內容
for (int i = sheet.getFirstRowNum(); i < sheet.getPhysicalNumberOfRows(); i++) {
row = sheet.getRow(i);
for (int j = row.getFirstCellNum(); j < row.getPhysicalNumberOfCells(); j++) {
// 通過 row.getCell(j).toString() 獲取單元格內容,
cell = row.getCell(j).toString();
System.out.print(cell + "/t");
}
System.out.println("");
}
此過程直接傳入文件所在路徑,其他一些過程已經被自動實現。
3,測試,文件爲8列3563行數據,以文本方式讀取內容,
- public static void main(String[] args) {
- SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss:SS");
- TimeZone t = sdf.getTimeZone();
- t.setRawOffset(0);
- sdf.setTimeZone(t);
- Long startTime = System.currentTimeMillis();
- String fileName = "F://我的文檔//學生繳費代碼.xlsx";
- // 檢測代碼
- try {
- PoiReadExcel er = new PoiReadExcel();
- // 讀取excel2007
- er.testPoiExcel2007(fileName);
- } catch (Exception ex) {
- Logger.getLogger(FastexcelReadExcel.class.getName()).log(Level.SEVERE, null, ex);
- }
- Long endTime = System.currentTimeMillis();
- System.out.println("用時:" + sdf.format(new Date(endTime - startTime)));
- }
public static void main(String[] args) {
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss:SS");
TimeZone t = sdf.getTimeZone();
t.setRawOffset(0);
sdf.setTimeZone(t);
Long startTime = System.currentTimeMillis();
String fileName = "F://我的文檔//學生繳費代碼.xlsx";
// 檢測代碼
try {
PoiReadExcel er = new PoiReadExcel();
// 讀取excel2007
er.testPoiExcel2007(fileName);
} catch (Exception ex) {
Logger.getLogger(FastexcelReadExcel.class.getName()).log(Level.SEVERE, null, ex);
}
Long endTime = System.currentTimeMillis();
System.out.println("用時:" + sdf.format(new Date(endTime - startTime)));
}
讀取所用時間爲:4.172秒。