1.导入Jar包:poi-3.7-20101029.jar,poi-ooxml-3.7-20101029.jar,poi-ooxml-schemas-3.7-20101029.jar,xbean.jar,dom4j-1.6.1.jar
兼容均使用org.apache.poi.ss.usermodel.*包
package com.test.poi.read;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
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.ss.usermodel.WorkbookFactory;
public class ReadExcel {
public static void main(String[] args) {
InputStream is;
try {
File file = new File("d://789.xlsx");
is = new FileInputStream(file);
// is = new FileInputStream("d://123.xls");
Workbook wb = WorkbookFactory.create(is);
Sheet sheet = wb.getSheetAt(0);
//获得有多少列
int cells = sheet.getRow(0).getPhysicalNumberOfCells();
//获得总行数
int rows = sheet.getLastRowNum();
if(wb instanceof XSSFWorkbook) {
rows = rows -1;
}
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvalidFormatException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
注意事项:1.03和07版本的读出来的总行数是不一样的,07版本的比03版本的大1
2.07版本的不认为空行是空,要小心处理或判断空行
3.取cell中的值的时候要注意判断格式
在cell中填写的是数字或数字编号的情况下,poi读进来基本是用double来接受的
另外就是cell中的格式是可以人为的调整的,所以取cell中的值的时候基本上可以用这两种方式来设置取值后的格式转化:
DecimalFormat df = new DecimalFormat("#"); //取文本的时候可以用
DecimalFormat dfFloat = new DecimalFormat("#.00");//取数字