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(); //刷数据 }
- POI实践操作总结
- POI操作Excel总结
- poi 操作excel2007总结
- poi 操作excel2007总结
- POI 操作 EXCEL 总结
- POI操作Excel总结
- poi操作word文档总结
- poi操作PPT文档总结
- Poi + JFreeChart 操作Excel总结。
- POI操作Excel方法总结
- java poi 操作excel总结
- POI操作Excel知识点总结
- Oracle操作实践总结
- 操作实践总结
- POI 实践
- poi实践
- POI操作Excel常用方法总结
- POI操作Excel常用方法总结
- iOS 代理协议
- 创建python单例实例的装饰器
- Python爬虫例子1
- iOS 适配iOS9
- CFileDlg实例
- POI实践操作总结
- nohup ./startWebLogic.sh >out.log 2>&1 &
- 我用Java写的象棋外挂成功了
- 背包系统(二)各个部分的整合和整体功能的实现
- JavaScript DOM(一)--页面加载完成事件与获取元素节点
- 02 python 学习
- python使用gensim进行文本相似度计算
- Java线程(六):线程池
- 【NIO详解】基于NIO的client与server