使用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("好了!");
}