关于用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) 版权声明: ...
随机推荐
- hdu5294||2015多校联合第一场1007 最短路+最大流
http://acm.hdu.edu.cn/showproblem.php? pid=5294 Problem Description Innocent Wu follows Dumb Zhang i ...
- 设计模式22---设计模式之解释器模式(Interpreter)(行为型)
1.讲解解释器模式 1.1解释器模式定义 给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子. 1.2解释器模式要点 解析器:把描述客户端调用要求的表达式, ...
- iOS UIScrollView 你可能不知道的奇技淫巧
iOS 的 UIScrollView 可以说是十分强大,巧妙地运用它可以得到一些意想不到的效果.本文将举几个 ScrollView 不常见运用的例子. 自带信息应用 这个界面既可以上下卷动,也可以左右 ...
- jQuery作用
jquery是前端里面比较总要的,是很强大的一个选择器. 表单: 1.$(":input") 查找所有的input元素 2.$("text") 匹配所有的 ...
- 19、XHTML
XHTML 可扩展超文本标签语言(EXtensible HyperText Markup Language). 是一种 W3C 标准. 更严格,更纯净的HTML代码. 目标是取代HTML代码. XHT ...
- PHP环境搭建所遇到的问题
下午学校的机房搭建PHP组合包appserv开发环境的时候是没有任何问题的,但是到了自己的电脑上以后下砸的32位appserve一直无法正常由浏览器的localhos或者127.0.0.1 进入其ap ...
- 在eclipse下面搭建Clojure开发运行环境
打开eclipse,点击菜单栏“help->Install New Software...", 然后,点击”add“, 在Location处输入 http://ccw.cgrand.n ...
- XE6 /XE8 & IOS开发之免证书真机调试三步走,生成iPA文件并安装到其它苹果设备上
XE6 & IOS开发之免证书真机调试(1):颁发属于自己的App签名证书(有图有真相) XE6 & IOS开发之免证书真机调试(2):连接真机并运行App(有图有真相) XE6 &a ...
- C# 多个线程一直跑着While(true)
在使用多线程的时候,开了多个线程一直在While(true),会造成CPU占用很高.这时候要在线程内加入一句Thread.Sleep(1),让他稍微睡一下.就不会消耗那么多CPU了. 代码: Thre ...
- [转]mysql自动定时备份数据库的最佳方法-支持windows系统
网上有很多关于window下Mysql自动备份的方法,可是真的能用的也没有几个,有些说的还非常的复杂,难以操作. 我们都知道mssql本身就自带了计划任务可以用来自动备份,可是mysql咱们要怎么样自 ...