使用java对excel内容读取

JAVA POI 方法

首先应先导入POI包,百度呗















然后进入JAVA代码

现在java类里面定义一个方法 

/*获取单元格的内容*/

 private static String getStringCellValue(XSSFCell xssfCell) {
        String strCell = "";
        switch (xssfCell.getCellType()) {
        case HSSFCell.CELL_TYPE_STRING:
            strCell = xssfCell.getStringCellValue();
            break;
        case HSSFCell.CELL_TYPE_NUMERIC:
            strCell = String.valueOf(xssfCell.getNumericCellValue());
            break;
        case HSSFCell.CELL_TYPE_BOOLEAN:
            strCell = String.valueOf(xssfCell.getBooleanCellValue());
            break;
        case HSSFCell.CELL_TYPE_BLANK:
            strCell = "";
            break;
        default:
            strCell = "";
            break;
        }
        if (strCell.equals("") || strCell == null) {
            return "";
        }
        if (xssfCell == null) {
            return "";
        }
        return strCell;
    }


再创建一个方法 用于 /*判断该excel表类型*/

public static Workbook getWorkwork(InputStream is) throws IOException{
Workbook wb = null;    
         if(!is.markSupported()){    
             is = new PushbackInputStream(is,8);             
         }    
         if (POIFSFileSystem.hasPOIFSHeader(is)) {       //Excel2003及以下版本    
             wb = (Workbook) new HSSFWorkbook(is);    
         }else if (POIXMLDocument.hasOOXMLHeader(is)) {      //Excel2007及以上版本    
             wb = new XSSFWorkbook(is);      
         }else{    
             throw new IllegalArgumentException("你的Excel版本目前poi无法解析!");                      
         }    
   //  }    
 return wb;    
}


最后 

public static void main(String[] args) {
String filePath="C://Excel模板打印定制//people.xls"; //获取该excel表的具体位置

try {
FileInputStream is=new FileInputStream(filePath); //读取excel文件
Workbook wb=getWorkwork(is); //先判断该excel表的版本
Sheet sheet=wb.getSheetAt(0); //获取左下角的第一个表
int getallrow=sheet.getLastRowNum(); //获取该表的总行数
for(int i=0;i<=getallrow;i++){ //进入行循环
XSSFRow row3=(XSSFRow) sheet.getRow(i); //获取当前第几行
int c=row3.getPhysicalNumberOfCells(); //获取该行有多少列
String[] title=new String[c]; //定义一个String[]
for(int j=0;j<c;j++){ //进入列循环
title[j] = getStringCellValue(row3.getCell((short) j)); //调用第一个方法getStringCellValue()
system.out.println("第"+i+"行,第"+j+"列的内容是:"+title[i]); //打印测试是否正确获取所有单元格的内容
}
}
}

FileOutputStream os=new FileOutputStream(filePath);
wb.write(os);
is.close();
os.close();

} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("好了!");


}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值