`
123629996
  • 浏览: 291400 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

POI生成Excel工具类

阅读更多

废话不说,直接上代码

package com.sgcc.ahepc.util;

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

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.HSSFColor;


public class ExcelExportUtil {
	/**
	 * 支持多sheet生成
	 * @param list 展示列表
	 * @param titles 头信息
	 * @param columns 列字段
	 * @param sheetNames sheet名称
	 * @return
	 */
	public static HSSFWorkbook getBook(List<List<Map<String, Object>>> list,
String[] titles, String[] columns, List<String> sheetNames,int start) {
		
		// 创建新的Excel 工作簿
		 HSSFWorkbook workbook = new HSSFWorkbook();
		 //字体
		 HSSFFont font = workbook.createFont();
		 font.setFontName("仿宋");
		 font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//粗体显示
		 font.setFontHeightInPoints((short) 12);
		 
		 HSSFFont cellFont = workbook.createFont();
		 cellFont.setFontName("仿宋");
		 cellFont.setFontHeightInPoints((short) 12);
		 
		 HSSFCellStyle titleStyle = workbook.createCellStyle();
		 HSSFCellStyle cellStyle = workbook.createCellStyle();
		 //设置颜色
		 titleStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
		 titleStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
		 titleStyle.setFillForegroundColor(HSSFColor.SKY_BLUE.index);//前景颜色
		 titleStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);//填充方式,前色填充
		 //边框填充
		 titleStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN); //下边框
		 titleStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);//左边框
		 titleStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);//上边框
		 titleStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);//右边框
		 titleStyle.setFont(font);
		 titleStyle.setWrapText(false);
		 
		 cellStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
		 cellStyle.setAlignment(HSSFCellStyle.ALIGN_LEFT);
		 cellStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN); //下边框
		 cellStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);//左边框
		 cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);//上边框
		 cellStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);//右边框
		 cellStyle.setFont(cellFont);
		 cellStyle.setWrapText(false);
		// 根据sheet多少决定创建多少sheet
		
		for (int n = 0; n < sheetNames.size(); n++) {
			 HSSFSheet sheet = null;
			if (sheetNames != null && sheetNames.size()>0) {
				sheet = workbook.createSheet(sheetNames.get(n));
			} else {
				sheet = workbook.createSheet();
			}
			
			// 在索引0的位置创建行(最顶端的行)
			HSSFRow titleRow = sheet.createRow(start);
			titleRow.setHeightInPoints(18);
			//titleRow.setRowStyle(style);
			// 在索引0的位置创建单元格(左上端)
			for(int i=0;i<titles.length;i++){
				HSSFCell titleCell = titleRow.createCell(i);
				titleCell.setCellStyle(titleStyle);
				titleCell.setCellValue(titles[i]);
			}
			//填充数据,有多少记录就需要创建多少行记录
				List<Map<String,Object>> dataList = list.get(n);
				for(int l=0;l<dataList.size();l++){
					Map<String,Object> map = dataList.get(l);
					HSSFRow dRow = sheet.createRow(start+l+1);
					//根据标题的多少决定创建多少列,并根据列的名称找到对应的数据
					for(int k=0;k<columns.length;k++){
						HSSFCell dCell = dRow.createCell(k);
						dCell.setCellStyle(cellStyle);
						String val = String.
valueOf(map.get(columns[k].toUpperCase()));
						if(val == null || val.equals("null")){
							val = "";
						}
						dCell.setCellValue(val);
					}
				}

			for(int m=0;m<titles.length;m++){
				sheet.autoSizeColumn(m);
			//sheet.autoSizeColumn(m, true);
			//sheet.setColumnWidth(m, titles[m].getBytes().length*2*256);
			}
			
		}
		
		
		return workbook;
	}

}

 说有一点,这个类支持多sheet输出,采用键值对的关系运作。titiles是中文的标题,colums是键值,也就是list中map的key,所以在实用时要传入list,并且list中存放map。这个结果集实际上在使用 mybatis时实际上是很方便的。这里我用的就是mybatis,虽然有一定的局限性,但是是一种思路。利用java的反射实际上也很容易将实体类转换为这样的数据。

分享到:
评论

相关推荐

    java使用POI导出 Excel工具类

    java使用POI导出 Excel+图片工具类 ,里面含有poi jar包,只调用接口即可直接保存Excel。使用的时候需先把数据封装,具体包装需根据实际导出数据进行处理。文件demo中只提供包装格式。

    java poi导出excel含工具类以及示例

    String outputFile = "D:\\excel\\excel.xlsx"; OutputStream outputStream = new FileOutputStream(outputFile); UtilExcel utilExcel = new UtilExcel(); String titles = "所属区域,所属车间,当前处理人,描述...

    使用POI在Excel中动态生成图表工具类(支持柱状、组合、环状图、折线图、等常用图)

    使用poi在excel中生成各种常见的图像,比如饼状图(普通饼状图、三D图,环状体、折线图、柱状图、等~~)

    POI 生成EXCEL2007【含例子】

    NULL 博文链接:https://topbox163.iteye.com/blog/1114166

    使用ITEXT导出EXCEL工具类

    使用ITEXT导出EXCEL工具类使用ITEXT导出EXCEL工具类使用ITEXT导出EXCEL工具类使用ITEXT导出EXCEL工具类使用ITEXT导出EXCEL工具类

    SpringBoot整合poi实现Excel文件的导入和导出.pdf

    SpringBoot整合poi实现Excel文件的导入和导出,其中单独分装出一个ExcelFormatUtil工具类来实现对单元格数据格式进行判断。

    easyuiPoi导出Excel工具类封装(支持合并单元格)

    easyuiPoi 通过模板导出Excel、支持纵向合并单元格(合并重复内容)。压缩包包含公共工具类、示例模板、调用截图。

    poi导出excel并下载工具类(含有demo)

    封装 poi,使用实体的列表(List),可以使用实体属性(一个String数组)指定生成的列,可以指定文件标题,列标题,生成excel,并在页面进行导出

    poi excel导入、导出,工具类、jar包

    支持excel2003、2007,导入的直接传入MultipartFile.getInputStream(),返回List,String&gt;&gt;,再做处理。 导出的数据直接生成excel文档存在本地,返回路径。

    poi分多个sheet导出excel

    每个sheet允许导出50000条记录,可以配置,如果sheet中的记录数&gt;50000,则创建一个新sheet并从第一行开始导出记录

    邮件发送 poi 二维码 条形码等java常用的工具类

    POIUtil:poi工具类,excel导出 QrCodeUtil:二维码操作工具, 包括生成和读取 ShellUtil:shell命令操作工具,包括linux登陆,命令执行...... 较为简单,具体需要自行扩充 SignUtil:签名工具,包括MD5 位运算 ...

    SpringBoot使用poi实现Excel导入与导出

    poi版本3.17 这是一个针对于Excel进行操作的工具类,文档可生成 xsl与xlsx为后缀的Excel

    EasyExcel(生成Excel报表)基本操作.pdf

    Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及...

    poi读取excel 内存出现溢出问题

    针对读取、生成excel内存溢出问题,包括工具类和具体的实现

    用POI实现excel表格的定制化和模板化开发

    1. 该工具的目的在于支持excel表格的定制化开发,提供了基本默认样式类、以及公共模板类,加速不同样式表格的生成,很适合表格复杂多变的场景; 2. 数据、样式、excel模板分离,可分别配置,可任意组合复用; 3. ...

    swing+poi+解析excel,导入excel

    通过工具类中读取绝对路径下的excel文档。 将文档放入到List集合。 将List集合转换成List集合。 生成随机数。 最后将结果放入到swing页面中进行效果显示。 模拟10个同学玩lol随机分组。 同学名字在excel中动态配置。

    poi导出excel

    内含所有poi所需jar包,在工具类里传入 (list集合,exel保存路径)即可生成所需规格的excel,代妈是我从SSH项目中摘除的,欢迎分享

    java代码自动生成工具

    java代码自动生成工具: 1.根据Mysql数据库的表生成...2.将Excel表格数据生成java实体类,包括注释 3.包括源文件和生成好的jar工具,和示例文件 技术: java、log4j、poi表格操作、jdbc数据库操作、freeMarker模板使用

    java生成读取excel所需要的jar

    该文件里存放了java生成读取excel时,需要使用的jar,

    EasyExcel JAVA解析Excel工具 v3.3.4

    Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及...

Global site tag (gtag.js) - Google Analytics