POI实践操作总结

来源:互联网 发布:淘宝活动 编辑:程序博客网 时间:2024/05/19 06:51

目前常见读写word、excel和ppt等工具类开源javaAPI有两种方式,
一个是JXL(Java Excel API) 官网地址:http://jexcelapi.sourceforge.net/
一个是Apache的POI(Poor Obfuscation Implementation)官网地址:http://poi.apache.org/

POI支持微软的OLE2格式文件Office 2003及以下版本;同时支持微软的OOXML(Office Open XML)标准,也就是Office 2007以上版本。JXL只能实现对Excel 2003以下版本的支持。

POI使用HSSF对象操作OLE2格式Excel,文件后缀为.xls的;使用XSSF、SXSSF对象操作OOXML格式Excel,文件后缀为.xlsx的。

对于OLE2版本的Excel,一个Sheet工作表它的行最多支持到65536行,列支持到256列;
对于OOXML版本的Excel,一个Sheet工作表它的行支持到1048576行,列支持到16384列。

数据限制:

Excel2003   2007、2010

列: 255 16384
行: 65535 1048576

=================== 基础运用===================

新建工作簿:

HSSFWorkbook wb = new HSSFWorkbook();   

打开工作簿:

HSSFWorkbook wb = new HSSFWorkbook(new FileInputStream(FileName));

建立新的sheet对象:

HSSFSheet sheet = wb.createSheet("SheetName");

选择第一个工作簿:

HSSFSheet sheet = wb.getSheetAt(0);

设置工作簿的名称:

wb.setSheetName(0, "firstsheet");   

创建行对象:

HSSFRow nRow = null;nRow = sheet.createRow(1);          //第2行

指定列 创建单元格对象:

HSSFCell nCell = null;nCell = nRow.createCell((short)(2));        //第3列

指定列 创建单元格对象:

nCell.setCellValue("我是单元格"); //单元格对象赋值

设置样式 注意:样式不能重复设置

nCell.setCellStyle(leftStyle(wb));

字体修饰:

//设置单元格样式    private HSSFCellStyle leftStyle(HSSFWorkbook wb){        HSSFCellStyle curStyle = wb.createCellStyle();        HSSFFont curFont = wb.createFont();                 //设置字体        //curFont.setFontName("Times New Roman");               //设置英文字体        curFont.setFontName("微软雅黑");                    //设置英文字体        curFont.setCharSet(HSSFFont.DEFAULT_CHARSET);               //设置中文字体,那必须还要再对单元格进行编码设置        curFont.setFontHeightInPoints((short)10);               //字体大小        curFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);            //加粗        curStyle.setFont(curFont);curStyle.setBorderTop(HSSFCellStyle.BORDER_THICK);          //粗实线        curStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);            //实线               curStyle.setBorderLeft(HSSFCellStyle.BORDER_MEDIUM);         //比较粗实线        curStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);         //实线        curStyle.setWrapText(true);                         //换行           curStyle.setAlignment(HSSFCellStyle.ALIGN_RIGHT);           //横向具右对齐        curStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);       //单元格垂直居中        return curStyle;    }

设置行高:

nRow.setHeightInPoints(18);

设置列宽:

sheet.setColumnWidth((short)colNo, (short)(256*8));//注意必须*256,不然下载的文件列宽会很小很小

设置每列默认宽度:

sheet.setDefaultColumnWidth((short) 20); 

设置标题:
将第一行作为标题,即每页都打印此行 sheetN,startCol,stopCol,startRow,stopRow

wb.setRepeatingRowsAndColumns(0,1,8,0,1);

页脚:

HSSFFooter footer = sheet.getFooter();footer.setRight("第"+HSSFFooter.page()+"页 共"+HSSFFooter.numPages()+"页     ");    //页数

单元格自适应高度:

nRow.setHeightInPoints(height); 

合并单元格:

/*          * 设定合并单元格区域范围          *  firstRow  0-based          *  lastRow   0-based          *  firstCol  0-based          *  lastCol   0-based          */          CellRangeAddress cra=new CellRangeAddress(0, 3, 3, 9);                //在sheet里增加合并单元格          sheet.addMergedRegion(cra);          Row row = sheet.createRow(0);          Cell cell_1 = row.createCell(3);          cell_1.setCellValue("合并单元格数据内容");          //cell 位置3-9被合并成一个单元格,不管你怎样创建第4个cell还是第5个cell…然后在写数据。都是无法写入的。          Cell cell_2 = row.createCell(10);          cell_2.setCellValue("what's up ! ");  

一定要注意合并单元格后的赋值问题。如果想要输入合并单元格的数据内容,在设置cell对象的时候,cell ID必须为合并单元格的最小cell ID,写了其他cell ID就无法正常导入数据,该单元格内数据一定为空。

分页

sheet.setRowBreak(当前行); //设置分页符

插入图片

HSSFPatriarch patriarch = sheet.createDrawingPatriarch();       //add picturethis.setPicture(wb, patriarch, realPath+"make/xlsprint/logo.jpg", curRow, 2, curRow+4, 2);
// 指定图片类型为jpg    public void setPicture(HSSFWorkbook wb, HSSFPatriarch patriarch, String pic, int iRowStart, int iColStart, int iRowStop, int iColStop) throws IOException {        // 判断文件是否存在        File imgFile = new File(pic);        if (imgFile.exists()) {            // 图片处理            ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();            BufferedImage bufferImg = ImageIO.read(imgFile);            ImageIO.write(bufferImg, "jpg", byteArrayOut);            HSSFClientAnchor anchor = new HSSFClientAnchor(20, 1, 1018, 0, (short) (iColStart), iRowStart, (short) (iColStop), iRowStop);            patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_JPEG));        }    }

插入一条线

pioUtil.setLine(wb, patriarch, curRow, 2, curRow, 8);   //draw line

设置数值类型

nCell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);

设置公式

nCell.setCellType(HSSFCell.CELL_TYPE_FORMULA);nCell.setCellFormula("F11*H11");

文件下载:

public void download(ByteArrayOutputStream byteArrayOutputStream, HttpServletResponse response, String returnName) throws IOException{        response.setContentType("application/octet-stream;charset=utf-8");        //returnName = response.encodeURL(new String(returnName.getBytes(),"iso8859-1"));           //保存的文件名,必须和页面编码一致,否则乱码        HttpServletRequest request = ServletActionContext.getRequest();        String agent = request.getHeader("user-agent");        returnName = encodeDownloadFilename(returnName,agent);        response.addHeader("Content-Disposition",   "attachment;filename=" + returnName);          response.setContentLength(byteArrayOutputStream.size());        ServletOutputStream outputstream = response.getOutputStream();  //取得输出流        byteArrayOutputStream.writeTo(outputstream);                    //写到输出流        byteArrayOutputStream.close();                                  //关闭        outputstream.flush();                                           //刷数据    }
原创粉丝点击