关于用POI和EXCEL交互的问题
废话不多说,直接通过例子来说明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" );
2.为防止导出的文件名出现乱码,需要对文件名进行URI解码,可以添加如下设置
上面的第二行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交互的问题的更多相关文章
- APACHE POI教程 --java应用程序用POI与Excel交互
POI报表 --用POI与Excel交互 AURISOFT 第一章 POI简介 --Jakata Poi HSSF:纯java的Excel解决方案 在我们实际的开发中,表现层的解决方案虽然有多样,但是 ...
- POI操作Excel
POI和Excel简介 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作 ...
- POI对Excel自定义日期格式的读取
用POI读取Excel数据:(版本号:POI3.7) 1.读取Excel private List<String[]> rosolveFile(InputStream is, String ...
- poi导出excel
Java使用poi组件导出excel报表,能导出excel报表的还可以使用jxl组件,但jxl想对于poi功能有限,jxl应该不能载excel插入浮动层图片,poi能很好的实现输出excel各种功能, ...
- JAVA的POI操作Excel
1.1Excel简介 一个excel文件就是一个工作簿workbook,一个工作簿中可以创建多张工作表sheet,而一个工作表中包含多个单元格Cell,这些单元格都是由列(Column)行(Row)组 ...
- POI导出excel日期格式
参考帖子: [1]http://www.ithao123.cn/content-2028409.html [2]http://javacrazyer.iteye.com/blog/894850 再读本 ...
- 使用jxl,poi读取excel文件
作用:在java后台添加一个方法,读取导入的excel内容,根据需要返回相应的sql语句,以完成对临时表的插入操作. 使用jxl读取excel文件 package com.sixthf.bi.sapp ...
- POI读取Excel内容格式化
在用POI读取Excel内容时,经常会遇到数据格式化的问题. 比如:数字12365会变为12365.0;字符串数字123也会变为123.0,甚至会被变为科学计数法.另外日期格式化也是一个头疼的问题.其 ...
- Java Struts2 POI创建Excel文件并实现文件下载
Java Struts2 POI创建Excel文件并实现文件下载2013-09-04 18:53 6059人阅读 评论(1) 收藏 举报 分类: Java EE(49) Struts(6) 版权声明: ...
随机推荐
- jquery+正則表達式验证邮箱格式的样例
js: $("#email").blur(function(){ //获取id相应的元素的值,去掉其左右的空格 var email = $.trim($('#email').val ...
- linux调度器系列
http://blog.csdn.net/wudongxu/article/category/791519
- python下载IGS观测数据
最近在学习GPS数据软件处理,经常需要下载数据练习,反复去网站上很麻烦,于是就写了一个小小的爬虫,用的是韩国的服务器,使用了python中的ftplib库实现的 今天稍微改了一下代码,可以选择卫星系统 ...
- HTML的Get方法URL传递中文参数,解决乱码问题
本例中有使用JQuery. 资料参考:http://www.cnblogs.com/babycool/p/3169058.html 发送的HTML页面代码: <!DOCTYPE html> ...
- java之log4j的配置
java之log4j的配置 log4j有很多的优点,用起来很方便,就是配置起来有些麻烦,下面我介绍一下log4j的配置方法. log4j是用来记录日志的. 软件的运行过程离不开日志.日志主要用来记录系 ...
- CakePHP的文章分类的功能实现
前些天实现了[微个人.大家园]的文章文类功能.现在回忆一下,是如何完成的吧. 具体的操作步骤如下: 1.在文章posts表里添加一个列,category_id. 2.在数据库中添加一个数据表,cate ...
- 点击其它地方隐藏div/事件冒泡/sweet-alert阻止冒泡
点击document时把div隐藏,但点击div时阻止点击事件冒泡到document,从而实现“点击文档其它地方隐藏div,点击div本身不隐藏”.js代码如下:$("#div") ...
- R文件丢失异常原因汇总
引言: R文件丢失异常在java开发中是个比较常见的异常,造成这个异常的原因可能非常微小,但是给Android开发者们造成的麻烦可是巨大的,当程序员们费尽千辛万苦,找到自己错在哪里的时候,绝对会对自己 ...
- 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 ...
- 用PHP实现一个高效安全的ftp服务器(一)
摘要: 本文主要阐述使用PHP的swoole扩展实现ftp服务器,同时扩展ftp服务器个性化功能和安全性.真正实现一个自己完全掌控的ftp服务器,可以个性化定制的ftp服务器. 正文: FTP服务器想 ...