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. win10安装sqlserver2016准备

    win10安装sql server2016需要注意: 一.下载jdk-8u121-windows-x64.exe这个安装,这个检测不通过会影响安装 二.把万维网服务的这个去掉,这个影响数据库实例的创建 ...

  2. Echarts关系图-力引导布局

    需要做一个树形图,可以查看各个人员的关系. 可伸缩的力引导图-失败 刚开始,打算做一个可展开和伸缩的,搜索时候发现CSDN有一篇美美哒程序媛写的Echarts Force力导向图实现节点可折叠. 这里 ...

  3. Spring mybatis源码篇章-MybatisDAO文件解析(一)

    前言:通过阅读源码对实现机制进行了解有利于陶冶情操,承接前文Spring mybatis源码篇章-SqlSessionFactory 加载指定的mybatis主文件 Mybatis模板文件,其中的属性 ...

  4. 安徽省2016“京胜杯”程序设计大赛_D_梯田AGAIN

    梯田AGAIN Time Limit: 5000 MS Memory Limit: 65536 KB Total Submissions: 95 Accepted: 21 Description 大家 ...

  5. Java 线程宝典

    此文 为垃圾文 本人复习用的 emmm 多线程:指的是这个程序(一个进程)运行时产生了不止一个线程 并行与并发: 并行:多个cpu实例或者多台机器同时执行一段处理逻辑,是真正的同时. 并发:通过cpu ...

  6. 使用sed命令向文件中追加可变字符串

    1.如何向文件追加可变字符串,有如下两种方法 sed -i '1a '$s'' filename sed -i "1a $s" filename 注意: 以上命令是假定向文件fil ...

  7. 开源社交系统ThinkSNS+ 0.7.3研发周报

    什么是ThinkSNS+ ThinkSNS(简称TS),一款全平台综合性社交系统,为国内外大中小企业和创业者提供社会化软件研发及技术解决方案,目前最新版本为ThinkSNS+. 亲爱的粉丝,授权客户, ...

  8. mysql 中的socket 即 mysql.sock的作用

    这个mysql.sock应该是mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体,它比tcp快.通常遇到这个问题的原因就是你的mysql ser ...

  9. AIX smit下创建逻辑卷、添加文件系统并挂载

    --AIX smit下创建逻辑卷,添加文件系统并挂载------------------------------------------2013/10/15 首先创建逻辑卷smit lv ,这里没多大 ...

  10. 【转】C++智能指针简单剖析

    原文链接:http://www.cnblogs.com/lanxuezaipiao/p/4132096.html 导读 最近在补看 <C++ Primer Plus>第六版,这的确是本好书 ...