关于用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) 版权声明: ...
随机推荐
- header的用法小结(转)
php header()函数的具体作用是向客户端发送一个原始 HTTP 标头[Http Header]到客户端. 标头 (header) 是服务器以 HTTP 协义传 HTML 资料到浏览器前所送出的 ...
- CHAR 详解
CHAR(20):20指的是表中的a字段能存储的最大字符个数 CREATE TABLE `a` ( `a` char(20) DEFAULT NULL) ENGINE=InnoDB DEFAULT C ...
- Qt绘图之QGraphicsScene QGraphicsView QGraphicsItem详解
Graphics View提供了一个界面,它既可以管理大数量的定制2D graphical items,又可与它们交互,有一个view widget可以把这些项绘制出来,并支持旋转与缩放.这个柜架也包 ...
- StopWatch的用法
在学习spring的时候,看到关于统计时间的类,比较好奇,就记录下来,以便以后用到可以直接使用 org.springframework.util.StopWatch StopWatch该类在统计时间的 ...
- Apache MINA 框架之默认session管理类实现
DefaultSocketSessionConfig 类 extends AbstractSocketSessionConfig extends AbstractIoSessionConfig imp ...
- CSS3伪类nth-child结合transiton动画实现文字若影若现
css3伪类nth-child结合transiton动画实现文字若影若现收先创建一个div盒子,然后包裹在div中的有10个span标签每个span标签填上内容一次为A,B,C,D,E,F,G,H,I ...
- SQL server抽疯后修改sa密码无法成功的处理办法
今天上班打开电脑,发现尼玛所有项目启动后都报错,原因是说数据库sa的验证错误,无法进行数据库链接等等东西,简单地说---SQL server抽疯了!!!:( 昨天还好好的.而且没有修改过东西.为啥会出 ...
- EntityFramework在root目录web.config中的配置设置
未找到具有固定名称“System.Data.SqlClient”的 ADO.NET 提供程序的实体框架提供程序.请确保在应用程序配置文件的“entityFramework”节中注册了该提供程序.有关详 ...
- xcode中如何安装多个版本的模拟器
在xcode里面,安装的时间默认自带的有模拟器,有时间为了调试需要使用个多个版本的模拟器 在xcode -> preference 里面 选择download,这里你可下载你需要的模拟器
- css布局小技巧 2016.03.06
偶遇一个可爱的css布局学习网站,立刻学起来哟- max-width: 当页面左右宽度缩小时,为了避免出现左右滚动条的糟糕体验,就可以用到max-width啦!页面比宽度小时,会自动缩小哦- max- ...