POI实践操作总结

目前常见读写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 picture
this.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();                                           //刷数据
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值