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. 关于html转换为pdf案例的一些测试与思考

    由于工作所需,最近花时间研究了html转换为pdf的功能.html转换为pdf的关键技术是如何处理网页中复杂的css样式,通过在网上收集资料,发现目前html 转换为pdf的解决方案主要分为三类: 客 ...

  2. JS遍历属性和方法

    引用原文:http://www.cnblogs.com/lishenglyx/archive/2008/12/08/1350573.html#undefined <script language ...

  3. jquery 的页面下拉选项

    <!-- field的属性对应数据库表的内容 --> <th field="ANSWERNUM" formatter="formatterOption& ...

  4. Spring AOP With AspectJ

    一.AOP和拦截器 某些情况下,AOP和拦截器包括Filter能够实现同样的功能,一般都是请求即controller层的操作,这三个执行顺序为Filter>Interceptor>AOP, ...

  5. listView属性随笔--不断增加中。

    对于一个控件的认识总是会随着时间的推移,而变的逐渐深刻. 简单的就 android:layout_height:属性来说给的数值不同就会有不同的效果,有些时候你根本想不到是跟这个属性的设置有关. 有时 ...

  6. 一个最最简易的RPC框架雏形---转载自梁飞的博客

    查阅RPC与HTTP区别的时候, 无意间发现一篇博客,内容是一个简易的RPC服务框架, 仔细一看, 不得了,博主竟然就是阿里dubbo的作者. 原文链接在此: http://javatar.iteye ...

  7. [补档][Usaco2015 Jan]Grass Cownoisseur

    [Usaco2015 Jan]Grass Cownoisseur 题目 给一个有向图,然后选一条路径起点终点都为1的路径出来,有一次机会可以沿某条边逆方向走,问最多有多少个点可以被经过? (一个点在路 ...

  8. HH去散步[SDOI2009]

    题目描述 HH有个一成不变的习惯,喜欢饭后百步走.所谓百步走,就是散步,就是在一定的时间 内,走过一定的距离. 但是同时HH又是个喜欢变化的人,所以他不会立刻沿着刚刚走来的路走回. 又因为HH是个喜欢 ...

  9. dotnet core部署方式两则:CLI、IIS

    最近在使用dotnet core研究整个开发过程,使用下面两种方式部署: 一,使用 dotnet run 命令运行 在项目路径,shift+右键,选择 “在此处打开命令窗口”,在CMD窗口中运行“do ...

  10. location对象的使用

    Location 对象属性 属性 描述 hash 设置或返回从井号 (#) 开始的 URL(锚). host 设置或返回主机名和当前 URL 的端口号. hostname 设置或返回当前 URL 的主 ...