關(guān)于Java讀取Excel2007的文章在Google、百度上搜索一下,沒有太好的例子,實(shí)現(xiàn)的也不算太好。查看了一下Poi,最新的 POI 3.5 beta 4 支持讀寫 Excel2007和PPT2007(XLSX and PPTX),自己來(lái)實(shí)現(xiàn)Java讀取Excel2007了。 1,下載 POI 3.5 beta 4 解壓,把其中的jar包導(dǎo)入項(xiàng)目文件。以我的讀取為例,導(dǎo)入了以下jar包。  沒有配置 log4j,測(cè)試時(shí)報(bào)告警報(bào)信息,應(yīng)該為加載順序?qū)е碌某跏蓟瘑栴}造成(暫時(shí)沒有找原因)。
2,建立讀取 Excel2007 方法 -
- XSSFWorkbook xwb = new XSSFWorkbook(strPath);
-
- XSSFSheet sheet = xwb.getSheetAt(0);
-
- 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++) {
-
- cell = row.getCell(j).toString();
- System.out.print(cell + "\t");
- }
- System.out.println("");
- }
此過程直接傳入文件所在路徑,其他一些過程已經(jīng)被自動(dòng)實(shí)現(xiàn)。 3,測(cè)試,文件為8列3563行數(shù)據(jù),以文本方式讀取內(nèi)容, - 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:\\我的文檔\\學(xué)生繳費(fèi)代碼.xlsx";
-
- try {
- PoiReadExcel er = new PoiReadExcel();
-
- er.testPoiExcel2007(fileName);
- } catch (Exception ex) {
- Logger.getLogger(FastexcelReadExcel.class.getName()).log(Level.SEVERE, null, ex);
- }
- Long endTime = System.currentTimeMillis();
- System.out.println("用時(shí):" + sdf.format(new Date(endTime - startTime)));
- }
讀取所用時(shí)間為:4.172秒。
|