废话不多说,直接通过例子来说明POI的使用:

1.一个创建excel并写入数据的小例子,参照网上的一个例子:

public class CreateXL {

    /**
* @param args
*/
public static String outputFile="D:\\test.xls"; public static void main(String[] args) { //创建新的excel工作薄
try {
HSSFWorkbook workbook=new HSSFWorkbook();
// 在Excel工作簿中建一工作表,其名为缺省值
// 如要新建一名为"报表导出"的工作表,其语句为:
// HSSFSheet sheet = workbook.createSheet("报表导出");
HSSFSheet sheet=workbook.createSheet();
// 在索引0的位置创建行(最顶端的行)
HSSFRow row=sheet.createRow(0);
//在索引0的位置创建单元格(左上端)
HSSFCell cell=row.createCell(0);
// 定义单元格为字符串类型
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
// 在单元格中输入一些内容
cell.setCellValue("测试");
HSSFCellStyle cellStyle = workbook.createCellStyle();
cellStyle.setFillBackgroundColor(HSSFColor.LIGHT_TURQUOISE.index);//设置背景色
cellStyle.setFillForegroundColor(HSSFColor.LIGHT_GREEN.index);//设置前景色
//通过背景色和前景色的不同来使每行的颜色交叉展现,有待测试
cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//设置居中
sheet.setColumnWidth(0, 4000);
//sheet.setDefaultColumnWidth(12); //设置为12字节的宽度
cell.setCellStyle(cellStyle);
// 新建一输出文件流
FileOutputStream fout=new FileOutputStream(outputFile);
// 把相应的Excel 工作簿存盘
workbook.write(fout);
// 操作结束,关闭文件
fout.flush();
fout.close();
System.out.println("excel已生成");
} catch (Exception e) {
System.out.println("创建文件失败"+e);
//e.printStackTrace();
}
}
}

2.自己project中用到的

    public void rptImportModel() throws IOException {
String fileName="报表导入模板.xls";
HSSFWorkbook workbook=new HSSFWorkbook();
HSSFSheet sheet=workbook.createSheet();
HSSFRow row=sheet.createRow(0);
//创建单元格样式风格
HSSFCellStyle cellStyle = workbook.createCellStyle();
cellStyle.setFillForegroundColor(HSSFColor.LIGHT_GREEN.index);//设置前景色
cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//设置居中
//创建单元格
HSSFCell cellGrpNo = row.createCell(0);
cellGrpNo.setCellType(HSSFCell.CELL_TYPE_STRING);
cellGrpNo.setCellValue("组号");
cellGrpNo.setCellStyle(cellStyle);
HSSFCell cellNodeId=row.createCell(1);
cellNodeId.setCellType(HSSFCell.CELL_TYPE_STRING);
cellNodeId.setCellValue("报表节点ID");
cellNodeId.setCellStyle(cellStyle);
sheet.setColumnWidth(1, 8000);
//为防止文件名出现中文乱码,需要对文件名进行字符集转换
HttpServletResponse response = ServletActionContext.getResponse();
String name = new String(fileName.getBytes("GBK"), "ISO8859_1");
response.setHeader("Content-disposition", "attachment;filename=" + name); OutputStream os = null;
os = response.getOutputStream();
workbook.write(os);
os.flush();
os.close();
}

---------------------------------------------------------------------------------------------------------------------------------------------

总结如下:

1.想下载前询问(是打开文件还是保存到计算机)和通过IE浏览器直接选择相关应用程序插件打开两种方式:

  ①response.setHeader("Content-disposition","attachment;filename="+ "Example.xls" );

  ②response.setHeader("Content-Disposition", "inline; filename=" + fliename)
  目前用过的是第一种,第二种有待测试。

2.为防止导出的文件名出现乱码,需要对文件名进行URI解码,可以添加如下设置

       HttpServletResponse response = ServletActionContext.getResponse();
       String name = new String(fileName.getBytes("GBK"), "ISO8859_1");
       response.setHeader("Content-disposition", "attachment;filename=" + name );

  上面的第二行String()的函数查看API用法如下:

String(byte[] bytes, Charset charset) 
          通过使用指定的 charset 解码指定的 byte 数组,构造一个新的 String

3.导出的excel格式的设置问题,今天下午想把导出的excel的第一行第一列单元格的背景色设置颜色,试了好多次,确实有点坑爹,设置如下:

     HSSFCellStyle cellStyle = workbook.createCellStyle();
          cellStyle.setFillBackgroundColor(HSSFColor.LIGHT_TURQUOISE.index);//设置背景色

   cell.setCellStyle(cellStyle);
          除了添加上面几句,别忘了,需要在第二条语句下面添加下面的一句来将单元格填充,要不然没效果:

   cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

但是设置成这样子后,导出的excel单元格是黑色。试了好多次,发现了,用错方法了,第二条语句不应该是背景色,而是前景色!

   cellStyle.setFillForegroundColor(HSSFColor.LIGHT_GREEN.index);//设置前景色

 OK,这样子导出后,excel单元格有背景色了。但是,我想把某一列的宽度设置大一点

      sheet.setColumnWidth(0, 4000);

   感觉4000数据太大?但展示出来后不大,单元格宽度变长了,满足需求。也算是提供一个参考值。第一个参数表示设置第几列(从0开始),第二个参数表示设置的宽度大小。也不知道 这个数值设置大小有什么规律,反正我是没找出来,设置为负数结果宽度变的很大很大。

     当然也可以将所有列的宽度都设置大一点,可以用下面的方法

     sheet.setDefaultColumnWidth(12);  //设置为12字节的宽度

但我是只是把某一列的宽度设置大点,所以上面的方法不合适。

参考文档连接:http://bbs.csdn.net/topics/360003997

        http://luxhua.iteye.com/blog/464394

        http://hi.baidu.com/yljf1314/item/008762d1c9d5dc52d73aae47

        http://www.cnblogs.com/zhenmingliu/archive/2012/04/25/2469396.html

关于用POI和EXCEL交互的问题的更多相关文章

  1. APACHE POI教程 --java应用程序用POI与Excel交互

    POI报表 --用POI与Excel交互 AURISOFT 第一章 POI简介 --Jakata Poi HSSF:纯java的Excel解决方案 在我们实际的开发中,表现层的解决方案虽然有多样,但是 ...

  2. POI操作Excel

    POI和Excel简介 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作 ...

  3. POI对Excel自定义日期格式的读取

    用POI读取Excel数据:(版本号:POI3.7) 1.读取Excel private List<String[]> rosolveFile(InputStream is, String ...

  4. poi导出excel

    Java使用poi组件导出excel报表,能导出excel报表的还可以使用jxl组件,但jxl想对于poi功能有限,jxl应该不能载excel插入浮动层图片,poi能很好的实现输出excel各种功能, ...

  5. JAVA的POI操作Excel

    1.1Excel简介 一个excel文件就是一个工作簿workbook,一个工作簿中可以创建多张工作表sheet,而一个工作表中包含多个单元格Cell,这些单元格都是由列(Column)行(Row)组 ...

  6. POI导出excel日期格式

    参考帖子: [1]http://www.ithao123.cn/content-2028409.html [2]http://javacrazyer.iteye.com/blog/894850 再读本 ...

  7. 使用jxl,poi读取excel文件

    作用:在java后台添加一个方法,读取导入的excel内容,根据需要返回相应的sql语句,以完成对临时表的插入操作. 使用jxl读取excel文件 package com.sixthf.bi.sapp ...

  8. POI读取Excel内容格式化

    在用POI读取Excel内容时,经常会遇到数据格式化的问题. 比如:数字12365会变为12365.0;字符串数字123也会变为123.0,甚至会被变为科学计数法.另外日期格式化也是一个头疼的问题.其 ...

  9. Java Struts2 POI创建Excel文件并实现文件下载

    Java Struts2 POI创建Excel文件并实现文件下载2013-09-04 18:53 6059人阅读 评论(1) 收藏 举报 分类: Java EE(49) Struts(6) 版权声明: ...

随机推荐

  1. jquery+正則表達式验证邮箱格式的样例

    js: $("#email").blur(function(){ //获取id相应的元素的值,去掉其左右的空格 var email = $.trim($('#email').val ...

  2. linux调度器系列

    http://blog.csdn.net/wudongxu/article/category/791519

  3. python下载IGS观测数据

    最近在学习GPS数据软件处理,经常需要下载数据练习,反复去网站上很麻烦,于是就写了一个小小的爬虫,用的是韩国的服务器,使用了python中的ftplib库实现的 今天稍微改了一下代码,可以选择卫星系统 ...

  4. HTML的Get方法URL传递中文参数,解决乱码问题

    本例中有使用JQuery. 资料参考:http://www.cnblogs.com/babycool/p/3169058.html 发送的HTML页面代码: <!DOCTYPE html> ...

  5. java之log4j的配置

    java之log4j的配置 log4j有很多的优点,用起来很方便,就是配置起来有些麻烦,下面我介绍一下log4j的配置方法. log4j是用来记录日志的. 软件的运行过程离不开日志.日志主要用来记录系 ...

  6. CakePHP的文章分类的功能实现

    前些天实现了[微个人.大家园]的文章文类功能.现在回忆一下,是如何完成的吧. 具体的操作步骤如下: 1.在文章posts表里添加一个列,category_id. 2.在数据库中添加一个数据表,cate ...

  7. 点击其它地方隐藏div/事件冒泡/sweet-alert阻止冒泡

    点击document时把div隐藏,但点击div时阻止点击事件冒泡到document,从而实现“点击文档其它地方隐藏div,点击div本身不隐藏”.js代码如下:$("#div") ...

  8. R文件丢失异常原因汇总

    引言: R文件丢失异常在java开发中是个比较常见的异常,造成这个异常的原因可能非常微小,但是给Android开发者们造成的麻烦可是巨大的,当程序员们费尽千辛万苦,找到自己错在哪里的时候,绝对会对自己 ...

  9. oracle 触发器number判断空值,:NEW赋值,for each row,sql变量引号,to_date,to_char

    1.number类型在库中可能存在null这种数据 判断是否为空时要用如下: IF(nvl(:NEW.BACAH,0) <>0) 不能用IF(BACAH IS NOT NULL) 2. 2 ...

  10. 用PHP实现一个高效安全的ftp服务器(一)

    摘要: 本文主要阐述使用PHP的swoole扩展实现ftp服务器,同时扩展ftp服务器个性化功能和安全性.真正实现一个自己完全掌控的ftp服务器,可以个性化定制的ftp服务器. 正文: FTP服务器想 ...