poi的jar下载地址:http://poi.apache.org/

下载后会有很多jar,但是如果只是简单的excel报表的话,导入一个poi-版本号-日期.jar就可以了。

导出代码:

private void outputExcel(String queryDate, String[] headers,
List<List<String>> diaochas, HttpServletRequest request,
HttpServletResponse response) throws IOException {
HSSFWorkbook workbook = new HSSFWorkbook();
//createSheet(excel工作表名)
HSSFSheet sheet = workbook.createSheet(queryDate);
//下面是设置excel表中标题的样式
HSSFCellStyle title_style = workbook.createCellStyle();
title_style.setFillForegroundColor(HSSFColor.SKY_BLUE.index);
title_style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
title_style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
title_style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
title_style.setBorderRight(HSSFCellStyle.BORDER_THIN);
title_style.setBorderTop(HSSFCellStyle.BORDER_THIN);
title_style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
HSSFFont title_font = workbook.createFont();
title_font.setColor(HSSFColor.VIOLET.index);
title_font.setFontHeightInPoints((short) 12);
title_font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
title_style.setFont(title_font);
//内容的样式
HSSFCellStyle content_style = workbook.createCellStyle();
content_style.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);
content_style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
content_style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
content_style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
content_style.setBorderRight(HSSFCellStyle.BORDER_THIN);
content_style.setBorderTop(HSSFCellStyle.BORDER_THIN);
content_style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
content_style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
HSSFFont content_font = workbook.createFont();
content_font.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);
content_style.setFont(content_font);
//填充标题内容
HSSFRow row = sheet.createRow(0);
for (int i = 0; i < headers.length; i++) {
//设置标题的宽度自适应
sheet.setColumnWidth(i, headers[i].getBytes().length * 2 * 256);
HSSFCell cell = row.createCell(i);
cell.setCellStyle(title_style);
HSSFRichTextString text = new HSSFRichTextString(headers[i]);
cell.setCellValue(text);
}
//填充内容 囧。。。偷懒没有建立对象,直接用List存放的数据。
for (int i = 0; i < diaochas.size(); i++) {
row = sheet.createRow(i + 1);
List<String> diaocha = diaochas.get(i);
for (int j = 0; j < diaocha.size(); j++) {
HSSFCell cell = row.createCell(j);
cell.setCellStyle(content_style);
HSSFRichTextString richString = new HSSFRichTextString(
diaocha.get(j));
cell.setCellValue(richString);
}
}
//这里调用reset()因为我在别的代码中调用了response.getWriter();
response.reset();
response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-disposition", "attachment;filename="
+ queryDate + ".xls");
OutputStream ouputStream = response.getOutputStream();
workbook.write(ouputStream);
ouputStream.flush();
ouputStream.close();
}

嗯 附加一个mysql函数获取年月的

date_format(formatdate,'%Y-%m')

最后提示一点是,在请求导出的时候,不能用ajax请求,会没有反映的。

java poi 导出excel的更多相关文章

  1. 重构:以Java POI 导出EXCEL为例

    重构 开头先抛出几个问题吧,这几个问题也是<重构:改善既有代码的设计>这本书第2章的问题. 什么是重构? 为什么要重构? 什么时候要重构? 接下来就从这几个问题出发,通过这几个问题来系统的 ...

  2. Java POI 导出EXCEL经典实现 Java导出Excel

    转自http://blog.csdn.net/evangel_z/article/details/7332535 在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者 ...

  3. 重构:以Java POI 导出EXCEL为例2

    前言 上一篇博文已经将一些对象抽象成成员变量以及将一些代码块提炼成函数.这一节将会继续重构原有的代码,将一些函数抽象成类,增加成员变量,将传入的参数合成类等等. 上一篇博文地址:http://www. ...

  4. java:POI导出excel

    POI是一个开源项目,专用于java平台上操作MS OFFICE,企业应用开发中可用它方便导出Excel. 下面是使用示例: 1.maven中先添加依赖项 <dependency> < ...

  5. Java POI 导出excel表

    1.首先下载poi-3.6-20091214.jar,下载地址如下: http://download.csdn.net/detail/evangel_z/3895051 2.Student.java ...

  6. java POI导出Excel文件数据库的数据

    在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.这里我简单实现导出Excel文件. POI jar ...

  7. Java POI导出Excel不弹框选择下载路径(下载文件不选择下载路径,默认) Chrome

    在Chrome浏览器中,Java导出Excel文件时,浏览器弹出提示框,需要选择下载路径 在Chrome中的高级设置中,把“下载前询问每个文件的保存位置”去掉就解决了 DEEPLOVE(LC)

  8. JAVA POI导出EXCEL 动态表头、多级表头、动态数据

    导出Excel文件是业务中经常遇到的需求,以下是经常遇到的一些问题: 1,导出中文文件名乱码 String filename = "sheet1";response.setChar ...

  9. java poi导出EXCEL xls文件代码

    String _currentPage = request.getParameter("currentPage"); Integer currentPage = 0; if(_cu ...

  10. Java POI 导出EXCEL经典实现

    import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; i ...

随机推荐

  1. C#中Dispose、析构函数、close的区别

    一.Close与Dispose这两种方法的区别 调用完了对象的Close方法后,此对象有可能被重新进行使用:而Dispose方法来说,此对象所占有的资源需要被标记为无用了,也就是此对象要被销毁,不能再 ...

  2. poj1716 Integer Intervals(差分约束)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud Integer Intervals Time Limit: 1000MS   Me ...

  3. JQuery阻止表单提交的方法总结 - 使用onsubmit()验证表单并阻止非法提交

    方法1:<form onsubmit="javascript:confirm()"> 方法内返回false阻止表单提交 示例:代码检测textarea内填写的长度,未填 ...

  4. 那些我希望在一开始使用 Zsh(oh-my-zsh) 时就知道的

    原文地址:http://segmentfault.com/a/1190000002658335  作者:xavier 自带的插件 其实我用了 oh-my-zsh 快三个月后才知道原来他自带了很多插件没 ...

  5. [TYVJ] P1044 数字三角形

    数字三角形 背景 Background 09年 USACO 11月月赛  铜牌第一道   描述 Description 示出了一个数字三角形. 请编一个程序计算从顶至底的某处的一条路径,使该路径所经过 ...

  6. BZOJ 1065 奥运物流

    http://www.lydsy.com/JudgeOnline/problem.php?id=1065 思路:由于n个点,有n条边,因此由根就会引出一个环,我们枚举环的长度,在那个长度断开,我们假设 ...

  7. C语言中预定义符 __FILE__, __LINE__, __FUNCTION__, __DATE__, __TIME__ 的使用演示

    本文演示了C语言中预定义符 __FILE__, __LINE__, __FUNCTION__, __DATE__, __TIME__ 的使用. 这几个预定义符的名称就没必要再介绍了,顾名思义嘛. // ...

  8. Delphi线程同步(临界区、互斥、信号量,包括详细代码)

    当有多个线程的时候,经常需要去同步这些线程以访问同一个数据或资源. 例如,假设有一个程序,其中一个线程用于把文件读到内存,而另一个线程用于统计文件的字符数.当然,在整个文件调入内存之前,统计它的计数是 ...

  9. TextReader/TextWriter 的类

    TextReader以及TextWriter这两个类,非常有用,很多方法都接受它们作为参数. TextReader有两个子类: StringReader/StringWriter 用于读取字符串: S ...

  10. MySQL无法重启问题解决Warning: World-writable config file ‘/etc/my.cnf’ is ignored

    MySQL无法重启问题解决Warning: World-writable config file ‘/etc/my.cnf’ is ignored