poi 读取excel(03和07版本)--小结

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");//取数字

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值