java 操做Excel表格

对于Excel表格的解析、生成,java在 org.apache.poi 包中已经封装好了,使用比较简单。前端

解析Excel:

首先将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:

生成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();
相关文章
相关标签/搜索