poi包下载 API

使用POI生成Excel,大家都是赞个。可是狐狸觉得毕竟不是微软的产品,使用没有C#语言的好用,方法还是存在极限的。

下面总结狐狸自己用过的方法:

import org.apache.poi.hssf.usermodel.*;

@ 创建一个空白的excel

HSSFWorkbook workBook = new HSSFWorkbook();//是操作Excel2003的版本,扩展名是xls

@ 创建sheet页

HSSFSheet sheet = workBook.createSheet(String sheetName);//参数是设置sheet的名字

HSSFSheet sheet = workBook.createSheet();//sheet名字为默认sheet0

  @ sheet的其它常用设计

    在poi中并不存在某个单元格或者区域设置可编辑与不可编辑的方法,如果要控制某些列或者行是可以编辑的功能,必须先

    把sheet设置为密码保护模式,然后对指定的可编辑单元格设置保护失效。

  sheet.createFreezePane(int colSplit, int rowSplit);//冻结
  sheet.createFreezePane(int colSplit, int rowSplit, intleftmostColumn,int topRow);

    以上两种冻结方法只是区域参数不同。

  sheet.protectSheet("hisense");//密码保护,保护区域不可以修改

  HSSFCellStyle styleEdit = workBook.createCellStyle();//设置单元格格式

  styleEdit.setLocked(false);//该样式的保护失效

@ sheet中创建行

HSSFRow  row = sheet.createRow(int i);//生成第一行,i默认从0开始

row.setHeight((short)900);//设置行高

@ row中设置单元格

HSSFCell cell = row.createCell(int i);//在row行的第i+1列生成一个单元格

cell.setCellValue(new HSSFRichTextString(String text));//单元格赋值

cell.setZeroHeight(true);//将行高设置为零即可以隐藏

cell.setCellStyle(HSSFCellStyle style);//在单元格设置样式,样式在下面详解

若该style = styleEdit(上面sheet部分已经设置,见@ sheet的其它常用设计),则表示该单元格可以编辑

@ 单元格格式设置

  HSSFCellStyle style = workBook.createCellStyle();//创建单元格样式

  HSSFFont font = workBook.createFont();//设置字体

  font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//粗体显示

  style.setFont(font);//选择需要用到的字体格式

  HSSFDataFormat format = workBook.createDataFormat();//设置单元格格式
  style.setDataFormat(format.getFormat("@"));//设置单元格为文本格式
  style.setBorderRight(HSSFCellStyle.BORDER_THIN);//生成右边框   style.setRightBorderColor(HSSFColor.BLACK.index);//设置右边框颜色   style.setFillForegroundColor(IndexedColors.LIGHT_CORNFLOWER_BLUE.getIndex());//设置单元格背景
  style.setAlignment(HSSFCellStyle.ALIGN_RIGHT);//设置单元格右对齐

  边框的方法有:setBorderLeft,setBorderRight,setBorderTop,setBorderBottom

@ 合并单元格

    import org.apache.poi.hssf.util.Region;

    sheet.addMergedRegion(new Region(startRow, (short) startColumn, endRow, (short) endColumn)); 

================================================================================

读取excel数据的方法:

@ 读取excel文件

HSSFWorkbook workbook = new HSSFWorkbook(new java.io.FileInputStream( String filePath));

@ 根据sheet名读取sheet内页

HSSFSheet sheet = workbook.getSheet(String sheetName); 

@ 读取指定rowIndex的行

HSSFRow row = sheet.getRow(int rowIndex);

@ 读取单元格

HSSFCell cell = row.getCell(int index);

@ 读取单元格内的值

String value = row.getCell(int index).getStringCellValue();

 单元格内为空时,用上面方法会报错,解决方法:

HSSFCell Cell = row.getCell(int index);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);//设置为string类型
String value = row.getCell(index).getStringCellValue();

@ 用于辅助的好用方法:

int lastCol = row.getLastCellNum();//获取最后一列

int lastRow = sheet.getLastRowNum();//获取最后一行

@ 设置单元格值类型

cell.setCellValue(String);//设置单元格文本值

cell.setCellValue(Double);//设置单元格数字型值

通过以上的函数,可以完成excel的创建和读取操作。

*************************************************************************************************

狐狸最近在完成JSP动态表格导出excel形式并且设置excel受保护部分单元格可以编辑的属性,最后实现批量修改导入到数据的过程。

@ 将JSP页面表格导出excel形式:

  实现:利用poi设置excel格式,并且从数据库中读取数据导入到excel中,最后设置response如下:

   response.setContentType("application/vnd.ms-excel;charset=gbk");
response.setHeader("Content-Disposition", "attachment;filename=policyParam.xls");
OutputStream out = response.getOutputStream();
workBook.write(out);
out.close();

若导出的excel文件是中文,请先转码再导出。

   String fileName =java.net.URLEncoder.encode("导出","utf-8");
response.setContentType("application/vnd.ms-excel;charset=utf-8");
response.setHeader("Content-Disposition", "attachment;filename="+fileName+".xls");
OutputStream out = response.getOutputStream();
workBook.write(out);
out.close();

项目经理说页面的数据不是可以直接导成excel吗?我觉得与其从JSP读出数据,不如直接从数据库读取数据。

@ 将excel的数据批量导入到数据库

  第一步设计一个文件上传表单,同时校验excel合法性(模板是否符合当前的对象)

  第二步利用 com.jspsmart.upload.SmartUpload读取文件流,从文件流中读取excel数据。

  第三步将读到的数据利用JDBC更新到数据库,每1000条commit一次。

  第四步如果excel有不合法数据,那么回滚数据。

POI 自用API的更多相关文章

  1. POI 的API大全二

    1.POI结构与常用类 (1)POI介绍 Apache POI是Apache软件基金会的开源项目,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. .NET的开发 ...

  2. POI中文API文档

    一. POI简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 二. HSSF概况 HSSF 是 ...

  3. POI - Excel API

    一.概述    1. Apache POI是Apache软件基金会的开放源码函式库,POI提供API给java程式对Microsoft Office格式档案读和写的功能.    2. 结构       ...

  4. POI SXSSF API 导出1000万数据示例

    SXSSF是XSSF API的兼容流式扩展,在必须生成非常大的电子表格.并且堆空间有限时使用. SXSSF通过限制对滑动窗口内数据的访问实现低内存占用,而XSSF允许访问文档中的所有行. 不在窗口中的 ...

  5. poi API

    一. POI简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 二. HSSF概况 HSSF 是 ...

  6. poi 导入导出的api说明(大全)

    原文链接:http://www.cnblogs.com/qingruihappy/p/8443101.html poi 导入导出的api说明(大全) 一. POI简介 ApachePOI是Apache ...

  7. Excel poi API基础教程!

    原文转子: http://blog.csdn.net/yellowd1/article/details/44628701 登录|注册     yellowd1的专栏       目录视图 摘要视图 订 ...

  8. poi API大全

    一. POI简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 二. HSSF概况 HSSF 是 ...

  9. Java poi读取,写入Excel,处理row和cell可能为空的情况

    首先需要导入包 import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.poifs.filesystem.NP ...

随机推荐

  1. 【javascript】ajax的参数

    1. 常用参数 url type: contentType: dataType: data: success: error 2. 特殊参数 context: 这个对象用于设置Ajax相关回调函数的上下 ...

  2. 【javascript】变量作用范围

    一.全局变量&局部变量 test="" 全局变量 var test="" 局部变量,无块的概念,作用域为function 或者script块 二.有意思 ...

  3. Spring阅读方法

    转自:http://www.cnblogs.com/xing901022/p/4178963.html 最近没什么实质性的工作,正好有点时间,就想学学别人的代码.也看过一点源码,算是有了点阅读的经验, ...

  4. OpenFlow协议1.0及1.3版本分析

    OpenFlow是SDN控制器和交换之间交流的协议,在SDN领域有着十分重要的地位. OpenFlow协议发展到现在已经经过了1.0.1.3.1.4等版本.其中1.0和1.3版本使用的是最为广泛的. ...

  5. python socket.error: [Errno 10054] 解决方法

    我用的是python2.7   我搜网上10054错误解决方法的时候发现,大部分文章都是以python3为基础的,对于python2不适用. python socket.error: [Errno 1 ...

  6. [补档][Jxoi2012] 奇怪的道路

    [Jxoi2012] 奇怪的道路 题目 传送门 :http://www.lydsy.com/JudgeOnline/problem.php?id=3195 小宇从历史书上了解到一个古老的文明.这个文明 ...

  7. 图解虚数 - A Visual, Intuitive Gudie to Imaginary Numbers

    这是一篇发表在 betterexplained 上的文章.它通过类比.图解的方式简明地介绍了虚数的意义. 作者:Kalid 原文:A Visual, Intuitive Gudie to Imagin ...

  8. 认真地搞OI

    新博客的开头 OI生涯的开始 #include<cstdio> int main() { puts("Hello world!"); ; }

  9. Open-Falcon第七步安装报警模块(小米开源互联网企业级监控系统)

    sender调用各个公司提供的mail-provider和sms-provider,按照某个并发度,从redis中读取邮件.短信并发送,alarm生成的报警短信和报警邮件都是直接写入redis即可,s ...

  10. Selenium实现的技巧

    截图功能:    try { File srcFile = ((TakesScreenshot)dr).getScreenshotAs(OutputType.FILE);                ...