废话不说,直接上代码
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+图片工具类 ,里面含有poi jar包,只调用接口即可直接保存Excel。使用的时候需先把数据封装,具体包装需根据实际导出数据进行处理。文件demo中只提供包装格式。
String outputFile = "D:\\excel\\excel.xlsx"; OutputStream outputStream = new FileOutputStream(outputFile); UtilExcel utilExcel = new UtilExcel(); String titles = "所属区域,所属车间,当前处理人,描述...
使用poi在excel中生成各种常见的图像,比如饼状图(普通饼状图、三D图,环状体、折线图、柱状图、等~~)
NULL 博文链接:https://topbox163.iteye.com/blog/1114166
使用ITEXT导出EXCEL工具类使用ITEXT导出EXCEL工具类使用ITEXT导出EXCEL工具类使用ITEXT导出EXCEL工具类使用ITEXT导出EXCEL工具类
SpringBoot整合poi实现Excel文件的导入和导出,其中单独分装出一个ExcelFormatUtil工具类来实现对单元格数据格式进行判断。
easyuiPoi 通过模板导出Excel、支持纵向合并单元格(合并重复内容)。压缩包包含公共工具类、示例模板、调用截图。
封装 poi,使用实体的列表(List),可以使用实体属性(一个String数组)指定生成的列,可以指定文件标题,列标题,生成excel,并在页面进行导出
支持excel2003、2007,导入的直接传入MultipartFile.getInputStream(),返回List,String>>,再做处理。 导出的数据直接生成excel文档存在本地,返回路径。
每个sheet允许导出50000条记录,可以配置,如果sheet中的记录数>50000,则创建一个新sheet并从第一行开始导出记录
POIUtil:poi工具类,excel导出 QrCodeUtil:二维码操作工具, 包括生成和读取 ShellUtil:shell命令操作工具,包括linux登陆,命令执行...... 较为简单,具体需要自行扩充 SignUtil:签名工具,包括MD5 位运算 ...
poi版本3.17 这是一个针对于Excel进行操作的工具类,文档可生成 xsl与xlsx为后缀的Excel
Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及...
针对读取、生成excel内存溢出问题,包括工具类和具体的实现
1. 该工具的目的在于支持excel表格的定制化开发,提供了基本默认样式类、以及公共模板类,加速不同样式表格的生成,很适合表格复杂多变的场景; 2. 数据、样式、excel模板分离,可分别配置,可任意组合复用; 3. ...
通过工具类中读取绝对路径下的excel文档。 将文档放入到List集合。 将List集合转换成List集合。 生成随机数。 最后将结果放入到swing页面中进行效果显示。 模拟10个同学玩lol随机分组。 同学名字在excel中动态配置。
内含所有poi所需jar包,在工具类里传入 (list集合,exel保存路径)即可生成所需规格的excel,代妈是我从SSH项目中摘除的,欢迎分享
java代码自动生成工具: 1.根据Mysql数据库的表生成...2.将Excel表格数据生成java实体类,包括注释 3.包括源文件和生成好的jar工具,和示例文件 技术: java、log4j、poi表格操作、jdbc数据库操作、freeMarker模板使用
该文件里存放了java生成读取excel时,需要使用的jar,
Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及...