数据导出到Excel几乎是所有客户都会提出的一个需求。下面我就分享一下我的代码。

首先需要引入的jar包:

然后就是正式代码了。

package lcy._41_50;

import java.io.FileOutputStream;

import java.io.OutputStream;

import java.net.URLEncoder;

import javax.servlet.http.HttpServletResponse;

import org.apache.poi.hssf.usermodel.HSSFCell;

import org.apache.poi.hssf.usermodel.HSSFCellStyle;

import org.apache.poi.hssf.usermodel.HSSFFont;

import org.apache.poi.hssf.usermodel.HSSFRow;

import org.apache.poi.hssf.usermodel.HSSFSheet;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.hssf.util.CellRangeAddress;

import org.apache.poi.hssf.util.HSSFColor;

@SuppressWarnings( { "deprecation" })

public class Test46 {

public static void main(String[] args) throws Exception {

String sheetName = "用车统计表单";

String titleName = "用车申请数据统计表";

String fileName = "用车申请统计表单";

int columnNumber = 3;

int[] columnWidth = { 10, 20, 30 };

String[][] dataList = { { "001", "2015-01-01", "IT" },

{ "002", "2015-01-02", "市场部" }, { "003", "2015-01-03", "测试" } };

String[] columnName = { "单号", "申请时间", "申请部门" };

new Test46().ExportNoResponse(sheetName, titleName, fileName,

columnNumber, columnWidth, columnName, dataList);

}

public void ExportWithResponse(String sheetName, String titleName,

String fileName, int columnNumber, int[] columnWidth,

String[] columnName, String[][] dataList,

HttpServletResponse response) throws Exception {

if (columnNumber == columnWidth.length&& columnWidth.length == columnName.length) {

// 第一步,创建一个webbook,对应一个Excel文件

HSSFWorkbook wb = new HSSFWorkbook();

// 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet

HSSFSheet sheet = wb.createSheet(sheetName);

// sheet.setDefaultColumnWidth(15); //统一设置列宽

for (int i = 0; i < columnNumber; i++)

{

for (int j = 0; j <= i; j++)

{

if (i == j)

{

sheet.setColumnWidth(i, columnWidth[j] * 256); // 单独设置每列的宽

}

}

}

// 创建第0行 也就是标题

HSSFRow row1 = sheet.createRow((int) 0);

row1.setHeightInPoints(50);// 设备标题的高度

// 第三步创建标题的单元格样式style2以及字体样式headerFont1

HSSFCellStyle style2 = wb.createCellStyle();

style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);

style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);

style2.setFillForegroundColor(HSSFColor.LIGHT_TURQUOISE.index);

style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

HSSFFont headerFont1 = (HSSFFont) wb.createFont(); // 创建字体样式

headerFont1.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 字体加粗

headerFont1.setFontName("黑体"); // 设置字体类型

headerFont1.setFontHeightInPoints((short) 15); // 设置字体大小

style2.setFont(headerFont1); // 为标题样式设置字体样式

HSSFCell cell1 = row1.createCell(0);// 创建标题第一列

sheet.addMergedRegion(new CellRangeAddress(0, 0, 0,

columnNumber - 1)); // 合并列标题

cell1.setCellValue(titleName); // 设置值标题

cell1.setCellStyle(style2); // 设置标题样式

// 创建第1行 也就是表头

HSSFRow row = sheet.createRow((int) 1);

row.setHeightInPoints(37);// 设置表头高度

// 第四步,创建表头单元格样式 以及表头的字体样式

HSSFCellStyle style = wb.createCellStyle();

style.setWrapText(true);// 设置自动换行

style.setAlignment(HSSFCellStyle.ALIGN_CENTER);

style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 创建一个居中格式

style.setBottomBorderColor(HSSFColor.BLACK.index);

style.setBorderBottom(HSSFCellStyle.BORDER_THIN);

style.setBorderLeft(HSSFCellStyle.BORDER_THIN);

style.setBorderRight(HSSFCellStyle.BORDER_THIN);

style.setBorderTop(HSSFCellStyle.BORDER_THIN);

HSSFFont headerFont = (HSSFFont) wb.createFont(); // 创建字体样式

headerFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 字体加粗

headerFont.setFontName("黑体"); // 设置字体类型

headerFont.setFontHeightInPoints((short) 10); // 设置字体大小

style.setFont(headerFont); // 为标题样式设置字体样式

// 第四.一步,创建表头的列

for (int i = 0; i < columnNumber; i++)

{

HSSFCell cell = row.createCell(i);

cell.setCellValue(columnName[i]);

cell.setCellStyle(style);

}

// 第五步,创建单元格,并设置值

for (int i = 0; i < dataList.length; i++)

{

row = sheet.createRow((int) i + 2);

// 为数据内容设置特点新单元格样式1 自动换行 上下居中

HSSFCellStyle zidonghuanhang = wb.createCellStyle();

zidonghuanhang.setWrapText(true);// 设置自动换行

zidonghuanhang.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 创建一个居中格式

// 设置边框

zidonghuanhang.setBottomBorderColor(HSSFColor.BLACK.index);

zidonghuanhang.setBorderBottom(HSSFCellStyle.BORDER_THIN);

zidonghuanhang.setBorderLeft(HSSFCellStyle.BORDER_THIN);

zidonghuanhang.setBorderRight(HSSFCellStyle.BORDER_THIN);

zidonghuanhang.setBorderTop(HSSFCellStyle.BORDER_THIN);

// 为数据内容设置特点新单元格样式2 自动换行 上下居中左右也居中

HSSFCellStyle zidonghuanhang2 = wb.createCellStyle();

zidonghuanhang2.setWrapText(true);// 设置自动换行

zidonghuanhang2

.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 创建一个上下居中格式

zidonghuanhang2.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 左右居中

// 设置边框

zidonghuanhang2.setBottomBorderColor(HSSFColor.BLACK.index);

zidonghuanhang2.setBorderBottom(HSSFCellStyle.BORDER_THIN);

zidonghuanhang2.setBorderLeft(HSSFCellStyle.BORDER_THIN);

zidonghuanhang2.setBorderRight(HSSFCellStyle.BORDER_THIN);

zidonghuanhang2.setBorderTop(HSSFCellStyle.BORDER_THIN);

HSSFCell datacell = null;

for (int j = 0; j < columnNumber; j++)

{

datacell = row.createCell(j);

datacell.setCellValue(dataList[i][j]);

datacell.setCellStyle(zidonghuanhang2);

}

}

// 第六步,将文件存到浏览器设置的下载位置

String filename = fileName + ".xls";

response.setContentType("application/ms-excel;charset=UTF-8");

response.setHeader("Content-Disposition", "attachment;filename="

.concat(String.valueOf(URLEncoder.encode(filename, "UTF-8"))));

OutputStream out = response.getOutputStream();

try {

wb.write(out);// 将数据写出去

String str = "导出" + fileName + "成功!";

System.out.println(str);

} catch (Exception e) {

e.printStackTrace();

String str1 = "导出" + fileName + "失败!";

System.out.println(str1);

} finally {

out.close();

}

} else {

System.out.println("列数目长度名称三个数组长度要一致");

}

}

public void ExportNoResponse(String sheetName, String titleName,

String fileName, int columnNumber, int[] columnWidth,

String[] columnName, String[][] dataList) throws Exception {

if (columnNumber == columnWidth.length&& columnWidth.length == columnName.length) {

// 第一步,创建一个webbook,对应一个Excel文件

HSSFWorkbook wb = new HSSFWorkbook();

// 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet

HSSFSheet sheet = wb.createSheet(sheetName);

// sheet.setDefaultColumnWidth(15); //统一设置列宽

for (int i = 0; i < columnNumber; i++)

{

for (int j = 0; j <= i; j++)

{

if (i == j)

{

sheet.setColumnWidth(i, columnWidth[j] * 256); // 单独设置每列的宽

}

}

}

// 创建第0行 也就是标题

HSSFRow row1 = sheet.createRow((int) 0);

row1.setHeightInPoints(50);// 设备标题的高度

// 第三步创建标题的单元格样式style2以及字体样式headerFont1

HSSFCellStyle style2 = wb.createCellStyle();

style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);

style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);

style2.setFillForegroundColor(HSSFColor.LIGHT_TURQUOISE.index);

style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

HSSFFont headerFont1 = (HSSFFont) wb.createFont(); // 创建字体样式

headerFont1.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 字体加粗

headerFont1.setFontName("黑体"); // 设置字体类型

headerFont1.setFontHeightInPoints((short) 15); // 设置字体大小

style2.setFont(headerFont1); // 为标题样式设置字体样式

HSSFCell cell1 = row1.createCell(0);// 创建标题第一列

sheet.addMergedRegion(new CellRangeAddress(0, 0, 0,

columnNumber - 1)); // 合并第0到第17列

cell1.setCellValue(titleName); // 设置值标题

cell1.setCellStyle(style2); // 设置标题样式

// 创建第1行 也就是表头

HSSFRow row = sheet.createRow((int) 1);

row.setHeightInPoints(37);// 设置表头高度

// 第四步,创建表头单元格样式 以及表头的字体样式

HSSFCellStyle style = wb.createCellStyle();

style.setWrapText(true);// 设置自动换行

style.setAlignment(HSSFCellStyle.ALIGN_CENTER);

style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 创建一个居中格式

style.setBottomBorderColor(HSSFColor.BLACK.index);

style.setBorderBottom(HSSFCellStyle.BORDER_THIN);

style.setBorderLeft(HSSFCellStyle.BORDER_THIN);

style.setBorderRight(HSSFCellStyle.BORDER_THIN);

style.setBorderTop(HSSFCellStyle.BORDER_THIN);

HSSFFont headerFont = (HSSFFont) wb.createFont(); // 创建字体样式

headerFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 字体加粗

headerFont.setFontName("黑体"); // 设置字体类型

headerFont.setFontHeightInPoints((short) 10); // 设置字体大小

style.setFont(headerFont); // 为标题样式设置字体样式

// 第四.一步,创建表头的列

for (int i = 0; i < columnNumber; i++)

{

HSSFCell cell = row.createCell(i);

cell.setCellValue(columnName[i]);

cell.setCellStyle(style);

}

// 第五步,创建单元格,并设置值

for (int i = 0; i < dataList.length; i++)

{

row = sheet.createRow((int) i + 2);

// 为数据内容设置特点新单元格样式1 自动换行 上下居中

HSSFCellStyle zidonghuanhang = wb.createCellStyle();

zidonghuanhang.setWrapText(true);// 设置自动换行

zidonghuanhang

.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 创建一个居中格式

// 设置边框

zidonghuanhang.setBottomBorderColor(HSSFColor.BLACK.index);

zidonghuanhang.setBorderBottom(HSSFCellStyle.BORDER_THIN);

zidonghuanhang.setBorderLeft(HSSFCellStyle.BORDER_THIN);

zidonghuanhang.setBorderRight(HSSFCellStyle.BORDER_THIN);

zidonghuanhang.setBorderTop(HSSFCellStyle.BORDER_THIN);

// 为数据内容设置特点新单元格样式2 自动换行 上下居中左右也居中

HSSFCellStyle zidonghuanhang2 = wb.createCellStyle();

zidonghuanhang2.setWrapText(true);// 设置自动换行

zidonghuanhang2

.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 创建一个上下居中格式

zidonghuanhang2.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 左右居中

// 设置边框

zidonghuanhang2.setBottomBorderColor(HSSFColor.BLACK.index);

zidonghuanhang2.setBorderBottom(HSSFCellStyle.BORDER_THIN);

zidonghuanhang2.setBorderLeft(HSSFCellStyle.BORDER_THIN);

zidonghuanhang2.setBorderRight(HSSFCellStyle.BORDER_THIN);

zidonghuanhang2.setBorderTop(HSSFCellStyle.BORDER_THIN);

HSSFCell datacell = null;

for (int j = 0; j < columnNumber; j++)

{

datacell = row.createCell(j);

datacell.setCellValue(dataList[i][j]);

datacell.setCellStyle(zidonghuanhang2);

}

}

// 第六步,将文件存到指定位置

try {

FileOutputStream fout = new FileOutputStream("D:students.xls");

wb.write(fout);

String str = "导出" + fileName + "成功!";

System.out.println(str);

fout.close();

} catch (Exception e) {

e.printStackTrace();

String str1 = "导出" + fileName + "失败!";

System.out.println(str1);

}

} else {

System.out.println("列数目长度名称三个数组长度要一致");

}

}

}

为了本地测试效果,单独写了一个无response参数的ExportNoResponse方法,直接将文件保存到指定目录D盘。

两个方法的不同就在于第六步中,有response参数的方法可以将文件存到浏览器设置的下载位置。

下面是导出效果截图:

以上所述是小编给大家介绍的java导出Excel方法详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

java excel 导出_java导出Excel通用方法实例相关推荐

  1. java available用法_Java.io.BufferedInputStream.available()方法实例

    全屏 java.io.BufferedInputStream.available() 方法返回从输入流中读取不受阻塞,输入流方法的下一次调用的剩余字节数. 声明 以下是java.io.Buffered ...

  2. java boolean例子_java.lang.Boolean.booleanValue()方法实例

    全屏 java.lang.Boolean.booleanValue()返回该Boolean对象作为一个布尔原始值. 声明 以下是java.lang.Boolean.booleanValue()方法的声 ...

  3. 使用poi导出excel生成复杂多级表头通用方法

    使用poi导出excel生成复杂多级表头通用方法 话不多说,直接上代码,需要用的的实体类如下 话不多说,直接上代码,需要用的的实体类如下 package com.test;public class U ...

  4. java 获取用户的MAC地址多种方法实例详解

    java 获取用户的MAC地址多种方法实例详解 这篇文章主要介绍了JAVA实现获取用户的MAC地址的多种方法实例,需要的朋友可以参考下 java实现获取用户的MAC地址方法: 方法一:将本机地址与局域 ...

  5. java excel 导入导出_java中excel文件的导入和导出

    如有需要可以加我Q群[308742428]大家一起讨论技术,提供技术支持. 后面会不定时为大家更新文章,敬请期待. 前端上传excel文件到后台,后台接收后保存数据到数据库. 这里需要说明的一点是前端 ...

  6. java导出为excel文件_java导出数据到excel文件

    有的时候,将一些有用的数据导出到excel是很有必要的.比如说,我现在在做一个学校的在线教学平台,有一个需求是:将学生成绩导出到excel文件中去. 那怎样实现用java导出数据到excel文件呢?? ...

  7. java导出excel报表_java生成excel报表文件示例

    此次简单的操作将数据从数据库导出生成excel报表以及将excel数据导入数据库 首先建立数据库的连接池: package jdbc; import java.io.FileInputStream; ...

  8. java方法有excel实现_Java实现EXCEL操作(1)

    Java实现EXCEL操作(1) 1.实现方法: 现在有三种方法去实现:jxl .poi . FastExcel:97~2003 在这里只讲poi实现方法.poi的包可以去Apache官网上去下载:h ...

  9. java jxl使用_java创建excel示例(jxl使用方法)

    使用该API非Windows操作系统也可以通过纯Java应用来处理Excel数据表.因为是使用 Java编写的,所以我们在Web应用中可以通过JSP.Servlet来调用API实现对Excel数据表的 ...

  10. java excel生成_java操作excel表,包括创建、读取、以及修改【via 度娘】

    作者的网站上对它的特征有如下描述: ● 支持Excel 95-2000的所有版本 ● 生成Excel 2000标准格式 ● 支持字体.数字.日期操作 ● 能够修饰单元格属性 ● 支持图像和图表 应该说 ...

最新文章

  1. Myeclipse报错--Animation Start An internal error has occurred. java.lang.NullPointerException解决...
  2. 用友互联网战略的变与不变
  3. 你需要了解的 C++ 17 Top 19 新特性(附精彩评论)
  4. 构造函数,对象原型,实例对象三者之间的关系
  5. Tiny模板语言(VelocityPlus)初步入门
  6. K-Means算法Demo
  7. 关于如何打开一张jpg图片文件并存放到vector unsigned char中的讨论
  8. 大数据营销案例沃尔玛_实现大数据营销的方式有哪些
  9. 云视频会议对初创公司的益处
  10. 京东android插件化,Flutter 插件开发-接入京东SDK唤醒(ios篇)
  11. 【双十一精选】史上最强的宝贝详情页设计思路以及操作流程
  12. 简述微型计算机的发展历程,1.1 计算机的发展历程
  13. Day07 Scanner 类、 Random 类、 ArrayList 类 6.20
  14. Summary——CrowdPose: Efficient Crowded Scenes Pose Estimation and A New Benchmark
  15. GB28181 PS流传输格式详解
  16. 计算某一天是星期几(C语言,可运行)
  17. python保留两位小数_python格式化输出保留2位小数的实现方法
  18. 基于Opencv的图像卡通化
  19. java response excel_java-返回在servlet中创建的excel文件作为响应
  20. 如何在Java中转换Excel文件到图像?

热门文章

  1. libtorch Compiler Error C2951
  2. pytorch 数据加载性能对比
  3. from torch._C import * ImportError: DLL load failed 动态链接库(DLL)初始化例程失败
  4. C++中const char*, string 与char*的转化
  5. Boost1.62.0 + VS2015 配置
  6. java判断回文字符串几种简单的实现
  7. openTLD算法在opencv3的PatchGenerator
  8. opencv undefined reference to symbol '_ZN2c...异常
  9. python datasets_python基础之sklearn.datasets
  10. java电台数据解析_Java数据解析---SAX