java 导出excel

转载 2017年01月03日 14:46:23

import java.util.List;
import java.util.Map;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.usermodel.IndexedColors;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;

public class ExcelUtil {

	/**
	 * 创建excel文档, [@param](http://my.oschina.net/u/2303379) list 数据
	 * 
	 * @param keys
	 *            list中map的key数组集合
	 * @param columnNames
	 *            excel的列名
	 * */
	public static Workbook createWorkBook(List<Map<String, Object>> list,
			String[] keys, String columnNames[], String sheetName) {
		// 创建excel工作簿
		Workbook wb = new HSSFWorkbook();
		// 创建第一个sheet(页),并命名
		Sheet sheet = wb.createSheet(sheetName);
		// 手动设置列宽。第一个参数表示要为第几列设;,第二个参数表示列的宽度,n为列高的像素数。
		for (int i = 0; i < keys.length; i++) {
			sheet.setColumnWidth((short) i, (short) (35.7 * 150));
		}

		// 创建第一行
		Row row = sheet.createRow((short) 0);

		// 创建两种单元格格式
		CellStyle cs = wb.createCellStyle();
		CellStyle cs2 = wb.createCellStyle();

		// 创建两种字体
		Font f = wb.createFont();
		Font f2 = wb.createFont();

		// 创建第一种字体样式(用于列名)
		f.setFontHeightInPoints((short) 10);
		f.setColor(IndexedColors.BLACK.getIndex());
		f.setBoldweight(Font.BOLDWEIGHT_BOLD);

		// 创建第二种字体样式(用于值)
		f2.setFontHeightInPoints((short) 10);
		f2.setColor(IndexedColors.BLACK.getIndex());

		// Font f3=wb.createFont();
		// f3.setFontHeightInPoints((short) 10);
		// f3.setColor(IndexedColors.RED.getIndex());

		// 设置第一种单元格的样式(用于列名)
		cs.setFont(f);
		cs.setBorderLeft(CellStyle.BORDER_THIN);
		cs.setBorderRight(CellStyle.BORDER_THIN);
		cs.setBorderTop(CellStyle.BORDER_THIN);
		cs.setBorderBottom(CellStyle.BORDER_THIN);
		cs.setAlignment(CellStyle.ALIGN_CENTER);

		// 设置第二种单元格的样式(用于值)
		cs2.setFont(f2);
		cs2.setBorderLeft(CellStyle.BORDER_THIN);
		cs2.setBorderRight(CellStyle.BORDER_THIN);
		cs2.setBorderTop(CellStyle.BORDER_THIN);
		cs2.setBorderBottom(CellStyle.BORDER_THIN);
		cs2.setAlignment(CellStyle.ALIGN_CENTER);
		// 设置列名
		for (int i = 0; i < columnNames.length; i++) {
			Cell cell = row.createCell(i);
			cell.setCellValue(columnNames[i]);
			cell.setCellStyle(cs);
		}
		// 设置每行每列的值
		for (short i = 1; i <= list.size(); i++) {
			// Row 行,Cell 方格 , Row 和 Cell 都是从0开始计数的
			// 创建一行,在页sheet上
			Row row1 = sheet.createRow((short) i);
			// 在row行上创建一个方格
			for (short j = 0; j < keys.length; j++) {
				Cell cell = row1.createCell(j);
				cell.setCellValue(list.get(i - 1).get(keys[j]) == null ? " "
						: list.get(i - 1).get(keys[j]).toString());
				cell.setCellStyle(cs2);
			}
		}
		return wb;
	}

}



spring mvc 导出excel

@RequestMapping(value = "download_audit_knight_monitor")
	public void downloadNotificationKnightMonitor(String beginTime, String endTime, HttpServletRequest request,
			HttpServletResponse response) {
		String fileName = "审核骑士监控中心" + beginTime + "-" + endTime;
		@SuppressWarnings("unchecked")
		List<Map<String, Object>> list = (List<Map<String, Object>>) resultVo.getData();
		String columnNames[] = { "骑士编号", "骑士类型", "已审核数", "错误条数", "正确率", "开始时间", "结束时间" };// 列名
		String keys[] = { "kaccountName", "knightType", "operationCounts", "errorCount", "correctRate", "beginTime",
				"endTime" };// map中的key
		// list = createExcelRecord(list, keys, columnNames);
		ByteArrayOutputStream os = new ByteArrayOutputStream();
		try {
			ExcelUtil.createWorkBook(list, keys, columnNames, "审核骑士监控中心").write(os);
		} catch (IOException e) {
			e.printStackTrace();
		}
		byte[] content = os.toByteArray();
		InputStream is = new ByteArrayInputStream(content);
		// 设置response参数,可以打开下载页面
		response.reset();
		response.setContentType("application/vnd.ms-excel;charset=utf-8");
		response.setHeader("Content-Disposition",
				"attachment;filename=" + new String((fileName + ".xls").getBytes(), "iso-8859-1"));
		ServletOutputStream out = response.getOutputStream();
		BufferedInputStream bis = null;
		BufferedOutputStream bos = null;
		try {
			bis = new BufferedInputStream(is);
			bos = new BufferedOutputStream(out);
			byte[] buff = new byte[2048];
			int bytesRead;
			// Simple read/write loop.
			while (-1 != (bytesRead = bis.read(buff, 0, buff.length))) {
				bos.write(buff, 0, bytesRead);
			}
		} catch (final IOException e) {
			throw e;
		} finally {
			if (bis != null)
				bis.close();
			if (bos != null)
				bos.close();
		}
		return;
	}





JAVA导出EXCEL实现

JAVA导出EXCEL实现
  • yjclsx
  • yjclsx
  • 2016年05月09日 11:58
  • 8994

JAVA工具类(17)--Java导入导出Excel工具类ExcelUtil

实战 导出就是将List转化为Excel(listToExcel) 导入就是将Excel转化为List(excelToList) 导入导出中会出现各种各样的问题,比如:数据源为空、有重复行等,我...
  • lovoo
  • lovoo
  • 2016年07月25日 12:11
  • 31017

Java POI 导出EXCEL 实现 Java导出Excel

在web开发中,有一个经典的功能,就是数据的导入导出。特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作。而数据导出的格式一般是EXCEL或者PDF,我这里...
  • WoShiSuChaoSheng
  • WoShiSuChaoSheng
  • 2017年09月06日 17:57
  • 2188

java中如何导出excel表格

如果你想导入excel:请参考:http://blog.csdn.net/xuanzhangran/article/details/70158995 本框架使用ssm。 1:点击导出订单,按照你的...
  • xuanzhangran
  • xuanzhangran
  • 2017年01月24日 17:25
  • 12123

Java 实现导出Excel功能

Web 开发数据导出功能实现,POI方式导出Excel文件,支持 excel 2007以上;
  • u014266877
  • u014266877
  • 2016年12月16日 11:50
  • 4340

java导出Excel通用方法

java导出Excel通用方法
  • paincupid
  • paincupid
  • 2016年04月08日 13:06
  • 1950

Java生成和导出Excel文件

Java生成和导出Excel文件
  • mengtianbao
  • mengtianbao
  • 2015年10月08日 09:52
  • 1316

Java实现指定数据表导出生成Excel

1. 前言: 在开发过程中往往少不了自动生成excel,比如学校教务系统,医疗系统,公司财务或者是公司员工的工资预览表都会使用。 2. 准备阶段: 1、Java开发环境 2、所需要...
  • Ink4T
  • Ink4T
  • 2017年08月13日 21:13
  • 67121

java生成 excel 并导出文件

一、介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系统)。或者是:我们已经习惯用Excel打印。这样在...
  • xunwei0303
  • xunwei0303
  • 2016年11月18日 10:10
  • 12437

java实现赋值Excel模板并写入后导出

遇到复杂的表头excel导出,我们该怎么办呢?            package com.at21.gpd.action; import java.io.BufferedInputStream;...
  • u012788601
  • u012788601
  • 2016年10月02日 22:02
  • 8091
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java 导出excel
举报原因:
原因补充:

(最多只允许输入30个字)