对于Excel表格的解析、生成,java在 org.apache.poi 包中已经封装好了,使用比较简单。前端
首先将File文件转成InputStreamjava
InputStream in = file.getInputStream();
而后建立表格对象,若是是2003版本的使用 HSSFWorkbook,2007以上的使用 XSSFWorkbookajax
HSSFWorkbook workbook = new HSSFWorkbook(in);// 建立对Excel工做薄文件的引用
接下来获取工做表apache
HSSFSheet sheet = workbook.getSheetAt(0);// 引用第一张工做表
获取行app
HSSFRow row = sheet.getRow(0);//获取第一行
获取单元格spa
HSSFCell cell=row.getCell(0)//获取第一个单元格
获取单元格的内容excel
String str=cell.getStringCellValue();//文本 Double money=cell.getNumericCellValue();//数字
能够这样封装一下code
private static String getStringFormCell(HSSFCell cell) { try { return cell.getStringCellValue(); } catch (java.lang.IllegalStateException ex) { return String.valueOf(cell.getNumericCellValue()); } }
最后经过遍历行、列就能实现解析了orm
生成excel要注意网页前端用ajax请求不能接收文件流,能够直接用超连接的方式直接GET调用后台方法,js的写法就是对象
window.location.href=XXXXX //请求地址
建立excel
HSSFWorkbook hssfWorkbook = new HSSFWorkbook(); HSSFSheet sheet = hssfWorkbook.createSheet(sheetName);//建立工做表
建立行
HSSFRow row = sheet.createRow(rowIndex);
建立一个单元格的格式(可选)
HSSFCellStyle style = hssfWorkbook.createCellStyle(); style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 建立一个居中格式
建立一个单元格并设置格式、值
HSSFCell cell = row.createCell(cellIndex);
cell.setCellValue(cellValue);
cell.setCellStyle(style);
最后设置请求参数并输出文件
response.setContentType("application/msexcel;charset=UTF-8"); response.addHeader("Content-Disposition","attachment;filename=" + new String((fileName+ ".xls").getBytes("GBK"), "ISO8859_1")); OutputStream out = response.getOutputStream(); hssfWorkbook.write(out); out.flush(); out.close();