java poi excel 生成表格的工具封装

效果如下:

代码如下:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;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.ss.usermodel.CellType;
import org.apache.poi.ss.util.CellRangeAddress;
/*** 使用该类时,确定引入的poi相关的jar包* Maven如下:*         <!-- POI --><dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.15</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.15</version></dependency>* @author Mr.wang* @date 2018/06/14**/
public class ExcelUtils {public static void main(String[] args) throws IOException {List<String> title = Arrays.asList("姓名", "年龄", "生日", "邮箱");List<List<String>> personInfos = new ArrayList<List<String>>();List<String> person01 = Arrays.asList("Ben", "26", "1992-02-12", "ben@sina.com");List<String> person02 = Arrays.asList("Tom", "27", "1993-08-18", "tom@sina.com");List<String> person03 = Arrays.asList("Jack", "28", "1994-03-28", "jack@sina.com");List<String> person04 = Arrays.asList("恩索", "29", "1995-01-09", "enso@sina.com");personInfos.add(person01);personInfos.add(person02);personInfos.add(person03);personInfos.add(person04);File file = new File("D:/demo.xls");//createExcelFile(title, personInfos, file, null);createExcelFileWithHead(title, personInfos, file, null, "个人信息表");}/*** 由生成流的方法进一步封装成生成excel(.xls)的文件* @see #createExcelInStream(List, List, OutputStream, String)* @param title* @param listData* @param fileWithPathAndName* @param sheetName* @throws IOException*/public static void createExcelFile(List<String> title, List<List<String>> listData, File fileWithPathAndName,String sheetName) throws IOException {FileOutputStream fos=new FileOutputStream(fileWithPathAndName);createExcelInStream(title, listData, fos, sheetName);if(fos!=null) {fos.close();}}/*** 由生成流的方法进一步封装成生成excel(.xls)的文件* @see #createExcelInStreamWithHead(List, List, OutputStream, String, String)* @param title* @param listData* @param fileWithPathAndName* @param sheetName* @param header* @throws IOException*/public static void createExcelFileWithHead(List<String> title, List<List<String>> listData, File fileWithPathAndName,String sheetName,String header) throws IOException {FileOutputStream fos=new FileOutputStream(fileWithPathAndName);createExcelInStreamWithHead(title, listData, fos, sheetName, header);if(fos!=null) {fos.close();}}/*** create by Mr.wang 2018/06/14* * 生成excel流(不带表头)。以xls为后缀的文件,防止有些电脑不支持office07以上的* * @param title*            标题* @param listData*            数据内容* @param outputStream*            输出的流* @param sheetName*            创建的sheet(不是文件)的名称,如果有空,则采用sheet1作用默认的表名称* @throws IOException* * * example:*  *  List<String> title = Arrays.asList("姓名", "年龄", "生日", "邮箱");List<List<String>> personInfos = new ArrayList<List<String>>();List<String> person01 = Arrays.asList("Ben", "26", "1992-02-12", "ben@sina.com");List<String> person02 = Arrays.asList("Tom", "27", "1993-08-18", "tom@sina.com");List<String> person03 = Arrays.asList("Jack", "28", "1994-03-28", "jack@sina.com");List<String> person04 = Arrays.asList("恩索", "29", "1995-01-09", "enso@sina.com");personInfos.add(person01);personInfos.add(person02);personInfos.add(person03);personInfos.add(person04);File file = new File("D:/demo.xls");FileOutputStream fos=new FileOutputStream(file);createExcelFile(title, personInfos, fos, null);...* */@SuppressWarnings("deprecation")public static void createExcelInStream(List<String> title, List<List<String>> listData, OutputStream outputStream,String sheetName) throws IOException {// 创建工作簿HSSFWorkbook workBook = new HSSFWorkbook();// 创建工作表 工作表的名字叫helloWorldif (sheetName == null || sheetName.length() == 0) {sheetName = "sheet1";}HSSFSheet sheet = workBook.createSheet(sheetName);// 创建单元格,首先设置标题HSSFFont fontTitle = workBook.createFont();fontTitle.setBold(true);HSSFCellStyle titleStyle = workBook.createCellStyle();titleStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);titleStyle.setFont(fontTitle);HSSFRow titleRow = sheet.createRow(0);for (int i = 0; i < title.size(); i++) {HSSFCell titleCol = titleRow.createCell(i, CellType.STRING);titleCol.setCellValue(title.get(i));titleCol.setCellStyle(titleStyle);}sheet.autoSizeColumn(0);// 创建数据行HSSFCellStyle dataStyle = workBook.createCellStyle();dataStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);for (int i = 0; i < listData.size(); i++) {HSSFRow dataRow = sheet.createRow(i + 1);List<String> rowData = listData.get(i);for (int j = 0; j < rowData.size(); j++) {HSSFCell dataCol = dataRow.createCell(j, CellType.STRING);dataCol.setCellValue(rowData.get(j));dataCol.setCellStyle(dataStyle);}sheet.autoSizeColumn(i);}HSSFRow firstRow = sheet.getRow(0);int lastCellNum = firstRow.getLastCellNum();//为了美观,把所有的cell扩大1/2for(int i=0;i<lastCellNum;i++) {int columnWidth = sheet.getColumnWidth(i);sheet.setColumnWidth(i, columnWidth+columnWidth*1/2);}workBook.write(outputStream);workBook.close();// 最后记得关闭工作簿
    }/*** create by Mr.wang 2018/06/14* * 生成excel流(带表头)。以xls为后缀的文件,防止有些电脑不支持office07以上的* * @param title*            标题* @param listData*            数据内容* @param outputStream*            输出的流* @param sheetName*            创建的sheet(不是文件)的名称,如果有空,则采用sheet1作用默认的表名称* @param header*            表的表头* @throws IOException* * * example:*  *  List<String> title = Arrays.asList("姓名", "年龄", "生日", "邮箱");List<List<String>> personInfos = new ArrayList<List<String>>();List<String> person01 = Arrays.asList("Ben", "26", "1992-02-12", "ben@sina.com");List<String> person02 = Arrays.asList("Tom", "27", "1993-08-18", "tom@sina.com");List<String> person03 = Arrays.asList("Jack", "28", "1994-03-28", "jack@sina.com");List<String> person04 = Arrays.asList("恩索", "29", "1995-01-09", "enso@sina.com");personInfos.add(person01);personInfos.add(person02);personInfos.add(person03);personInfos.add(person04);File file = new File("D:/demo.xls");FileOutputStream fos=new FileOutputStream(file);createExcelFileWithHead(title, personInfos, fos, null, "个人信息表");...* */@SuppressWarnings("deprecation")public static void createExcelInStreamWithHead(List<String> title, List<List<String>> listData, OutputStream outputStream,String sheetName,String header) throws IOException {// 创建工作簿HSSFWorkbook workBook = new HSSFWorkbook();// 创建工作表 工作表的名字叫helloWorldif (sheetName == null || sheetName.length() == 0) {sheetName = "sheet1";}HSSFSheet sheet = workBook.createSheet(sheetName);//设置表头//参数说明:1:开始行 2:结束行  3:开始列 4:结束列  //比如我要合并 第二行到第四行的    第六列到第八列     sheet.addMergedRegion(new CellRangeAddress(1,3,5,7));  sheet.addMergedRegion(new CellRangeAddress(0,0,0,title.size()-1)); HSSFRow headerRow = sheet.createRow(0);HSSFCell headerCell = headerRow.createCell(0);// 创建单元格,首先设置标题HSSFFont font = workBook.createFont();short fontHeightInPoints = font.getFontHeightInPoints();font.setFontHeightInPoints((short)(fontHeightInPoints+2));font.setBold(true);HSSFCellStyle cellHeaderStyle = workBook.createCellStyle();cellHeaderStyle.setFont(font);cellHeaderStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);headerCell.setCellStyle(cellHeaderStyle);//可表头加粗,居中
        headerCell.setCellValue(header);//cellStyle.setAlignment(alignmentEnum);//还原,标题不居中HSSFFont fontTitle = workBook.createFont();fontTitle.setBold(true);HSSFCellStyle titleStyle = workBook.createCellStyle();titleStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);titleStyle.setFont(fontTitle);HSSFRow titleRow = sheet.createRow(1);for (int i = 0; i < title.size(); i++) {HSSFCell titleCol = titleRow.createCell(i, CellType.STRING);titleCol.setCellValue(title.get(i));titleCol.setCellStyle(titleStyle);}sheet.autoSizeColumn(1);// 创建数据行
        HSSFCellStyle dataStyle = workBook.createCellStyle();dataStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);for (int i = 0; i < listData.size(); i++) {HSSFRow dataRow = sheet.createRow(i + 2);List<String> rowData = listData.get(i);for (int j = 0; j < rowData.size(); j++) {HSSFCell dataCol = dataRow.createCell(j, CellType.STRING);dataCol.setCellValue(rowData.get(j));dataCol.setCellStyle(dataStyle);}sheet.autoSizeColumn(i);}HSSFRow firstRow = sheet.getRow(1);int lastCellNum = firstRow.getLastCellNum();//为了美观,把所有的cell扩大1/2for(int i=0;i<lastCellNum;i++) {int columnWidth = sheet.getColumnWidth(i);sheet.setColumnWidth(i, columnWidth+columnWidth*1/2);}workBook.write(outputStream);workBook.close();// 最后记得关闭工作簿
    }}

 

相关工具方法

/*** create by Mr.wang 2018/06/14* * 将简单的对象(读取不到父类的属性)转化成List<String>* * @param o 对象* @param convertMap 转换器 指定对象属性中某一个属性值如何转化为String。如果不需要,可以设置成null即可* @param args 指定要输出的属性,一般用于属性选择和排序 ,如果不需要,则不设置.如果要查找父类的属性,则自身及父类的属性全部定义在此处,不再自动搜索自身的属性*                 这里注意如果同样的属性要利用两次,可以使用field&alias的格式来指定转换器*                 例如:code,code&1---->code&1可以设定与之对应的转换器* @return* @throws IllegalArgumentException* @throws IllegalAccessException* @throws NoSuchFieldException* @throws SecurityException* * example:* {*         "name":"jack",*         "age":26,*         "birthday":new Date()* }* 转成* ["jack","26","2018-06-14 16:02:20"]*/public static List<String> convertSimpleObj2StringList(Object o,Map<String,FieldConvert> convertMap,String... args) throws IllegalArgumentException, IllegalAccessException, NoSuchFieldException, SecurityException{List<String> list=new ArrayList<String>();Class<? extends Object> objClas = o.getClass();if(args.length==0) {Field[] declaredFields = objClas.getDeclaredFields();for(Field f : declaredFields) {f.setAccessible(true);String fileName = f.getName();Object obj=f.get(o);//对应的属性没值,则设置为“/”
                processFieldValue(convertMap, list, fileName, obj);}}else {for(String ag : args) {String fieldKey=null;String convertKey=ag;if(ag.contains("&")) {String[] split = ag.split("&");fieldKey=split[0];}else {fieldKey=ag;}Object fieldValue = getFieldValue(o, fieldKey);processFieldValue(convertMap, list, convertKey, fieldValue);}}return list;}private static void processFieldValue(Map<String, FieldConvert> convertMap, List<String> list, String ag, Object fieldValue) {if(fieldValue==null) {list.add("/");return;}else {if(convertMap!=null&&convertMap.containsKey(ag)){FieldConvert filedConvert = convertMap.get(ag);String s = filedConvert.covertFiledValueToString(fieldValue);if(s!=null){list.add(s);}else{list.add("/");}}else{list.add(fieldValue.toString());}}}/*** create by Mr.wang 2018/06/14* @see #convertSimpleObj2StringList* @param objs* @param convertMap* @param args* @return* @throws IllegalArgumentException* @throws IllegalAccessException* @throws NoSuchFieldException* @throws SecurityException*/public static <T> List<List<String>> convertSimpleObjList2StringList(List<T> objs,Map<String,FieldConvert> convertMap,String... args) throws IllegalArgumentException, IllegalAccessException, NoSuchFieldException, SecurityException{List<List<String>> list=new ArrayList<List<String>>();for(T obj : objs) {list.add(convertSimpleObj2StringList(obj,convertMap,args));}return list;}/*** create by Mr.wang 2018/06/14* 通过反射,向上(父类)一直获取对象的属性,如果一直获取不到则抛 NoSuchFieldException 异常* @param obj 要操作的操作* @param fieldName 要获取的属性名称* @return* @throws NoSuchFieldException* @throws SecurityException* @throws IllegalArgumentException* @throws IllegalAccessException*/public static Object getFieldValue(Object obj,String fieldName) throws NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException {Class<? extends Object> class1 = obj.getClass();Field declaredField=null;try {declaredField = class1.getDeclaredField(fieldName);} catch (NoSuchFieldException e) {declaredField=null;}while(declaredField==null) {class1=class1.getSuperclass();if(class1==null) {throw new NoSuchFieldException();}try {declaredField = class1.getDeclaredField(fieldName);} catch (NoSuchFieldException e) {declaredField=null;}}declaredField.setAccessible(true);return declaredField.get(obj);}

 

 

 FieldConvert.java

public interface FieldConvert {String covertFiledValueToString(Object filedValue);
}

 

转载于:https://www.cnblogs.com/wangyang108/p/9182714.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/266898.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于java嵌入式数据库的选择,强烈建议H2 嵌入式数据库

2019独角兽企业重金招聘Python工程师标准>>> 不听红薯言&#xff0c;吃亏在眼前。 先发表个人意见&#xff0c;Derby是垃圾&#xff0c;H2王道。 这段时间开发movingLife合租记账软件过程中&#xff0c;开始是在MYSQL上做开发&#xff0c;要发布的时候&#xff0c;一…

linux可变剪切分析,SpliceR:一个用RNA-Seq数据进行可变剪接分类和预测潜在编码区域的R包...

SpliceR&#xff1a;一个用RNA-Seq数据进行可变剪接分类和预测潜在编码区域的R包Kristoffer Knudsen, Johannes Waage5Dec2013翻译&#xff1a;斑斑<23920620>2016年7月14日欢迎加入生物信息QQ群78750864讨论相关问题1简介SpliceR是一个可以对转录本完整isoform(剪接模式…

c语言自定义浮点函数,C语言float

C语言float教程C语言float定义详解语法float varname value;参数参数描述float定义 float 类型变量使用的类型。varname变量名。value可选&#xff0c;变量的初始值。说明使用 float 定义了一个 float 类型的变量 varname&#xff0c;并赋初值为 value。C语言float详解说明描述…

Block CONNECT method in httpd.conf

为什么80%的码农都做不了架构师&#xff1f;>>> RewriteEngine on RewriteCond %{REQUEST_METHOD} ^(CONNECT|TRACE)$ RewriteRule ^.*$ - [L,F] ProxyRequests Off ProxyRequest should be set to off, unless you have security protect in your web server. 转…

解决sharepoint2010的多行文本框的插入图片—【从sharepoint】的disabled问题

大家发现sharepoint2010的多行文本框的插入图片有个—【从sharepoint】插入图片的功能&#xff0c;但是看到的disabled。如下图&#xff1a; 怎么办呢&#xff1f;通过查找资料才知道原来可以这样解决 在这里我们新建一个自定义列表&#xff1a;【test】&#xff0c;并新建一个…

c语言16进制按10进制输出,C语言编程:写一个函数,输入一个16进制数,输出相应的10进制数。...

满意答案chengexin2013.05.27采纳率&#xff1a;59% 等级&#xff1a;11已帮助&#xff1a;10599人#include#include#include#define N 1000char str[N];int a[N],b[N];int main(void){void zsh();long ycl();int i,n;do{printf("请输入一个十六进制数:\n");scanf…

用ASP.NET Core MVC 和 EF Core 构建Web应用 (一)

系统必备 .NET Core 2.0.0 SDK 或更高版本。已安装 ASP.NET 和 Web 开发工作负载的 Visual Studio 2017 15.3 版或更高版本。创建Web应用程序 打开 Visual Studio 并创建一个新 ASP.NET Core C# web 项目名为”ContosoUniversity”。 从文件菜单上&#xff0c;选择新建 > 项…

第一个Django应用程序_part1

一、查看Django是否安装 参考文档&#xff1a;https://docs.djangoproject.com/en/1.11/intro/tutorial01/ 如果Django已经安装&#xff0c;可以看到安装的版本号&#xff0c;如果没有安装则会看到“No module named django”的错误。 MacBook-Pro:~ h$ python3 -m django --ve…

HTML 文档流和文本流的理解

文本流&#xff0c;概括地说其实就是一系列字符&#xff0c;是文档的读取和输出顺序&#xff0c;也就是我们通常看到的由左到右、由上而下的读取和输出形式&#xff0c;在网页中每个元素都是按照这个顺序进行排序和显示的&#xff0c;而position属性可以将元素从文本流脱离出来…

CCNA实验(一)

无线局域网&#xff08;WLAN&#xff09;回顾 使用无线射频信号、载波监听多路访问/冲突避免、半双工。 无线AP相当于以太网的HUB。 有些频段是受限的。 无线信号遇到的问题&#xff1a; l 反射 l 散射 l 信号吸收&#xff08;比如说穿墙&#xff09; 无线标准 l ITU-R l …

linux中postfix(基于源码)的邮件系统

一、安装前的准备工作&#xff1a; 首先配置yum服务器&#xff0c;安装dns 1、安装所需的rpm包&#xff0c;这包括以下这些&#xff1a; httpd, php, php-mysql, mysql, mysql-server, mysql-devel, openssl-devel, dovecot, perl-DBD-MySQL, tcl, tcl-devel, libart_lgpl, li…

UE4 集成讯飞听写插件

搞了几天&#xff0c;有些坑记录一下。 3个方面的知识需要学习 1、制作UE4插件 2、引入第三方库 3、讯飞听写的api 一看是参考 https://blog.csdn.net/u012793104/article/details/78067937 http://doc.xfyun.cn/msc_windows/%E8%AF%AD%E9%9F%B3%E5%90%AC%E5%86%99.html API&am…

c51单片机有几个终端语言,吃过大亏,才知道要从51单片机入手

原标题&#xff1a;吃过大亏&#xff0c;才知道要从51单片机入手在这里&#xff0c;我就不说什么是单片机了&#xff0c;而是说说怎样学单片机&#xff0c;就我个人而言先学51,因为这个单片机在中国市场上发展了几十年了&#xff0c;现在工程中用的比较多的也是MCS-51, 它的资料…

医疗项目中对网编的一些理解看法

医疗项目中对网编的一些理解看法。做网络营销都有一个前提&#xff0c;那就是以用户为中心&#xff0c;站在用户的角度考 虑问题。在网络营销中&#xff0c;网编如何提升充实自己&#xff1f;怎么获得信息渠道&#xff1f;见多&#xff1a;多看&#xff0c;多了解行业的变化&am…

android 自定义view画表格,Android自定义View实现课程表表格

自己闲下来时间写的一个课表控件&#xff0c;使用的自定义LinearLayout&#xff0c;里面View都是用代码实现的&#xff0c;最终效果如下图&#xff0c;写的可能有问题希望多多指点创建一个自定义LinearLayout 控件用来装载课程的信息和课程的周数&#xff0c;和节数大概的布局三…

26.中继器数据的添加与删除

选择中继器里面的数据集再选择增加行 勾上之后选择下方的增加行就可以填入数据了 用变量获取用户输入的各项内容 但是图片不能用公式操作 方法&#xff1a;通过右键单击图片获得图片的地址 图片中蓝色的部分就是相对路径 把这个路径放到中继器的数据里就可以用了 以上是添加&am…

android工作机制和内核,android内核剖析学习笔记:AMS(ActivityManagerService)内部原理和工作机制...

一、ActivityManagerService提供的主要功能&#xff1a;(1)统一调度各应用程序的Activity(2)内存管理(3)进程管理二、启动一个Activity的方式有以下几种&#xff1a;(1)在应用程序中调用startActivity启动指定的Activity(2)在Home程序中单击一个应用图标&#xff0c;启动新的Ac…

从.Net到Java学习第四篇——spring boot+redis

从.Net到Java学习系列目录 “学习java已经十天&#xff0c;有时也怀念当初.net的经典&#xff0c;让这语言将你我相连&#xff0c;怀念你......”接上一篇&#xff0c;本篇使用到的框架redis、FastJSON。 环境准备 安装redis&#xff0c;下图是我本机的redis绿色版&#xff0c;…

hdu 4409 Family Name List LCA +stl

http://acm.hdu.edu.cn/showproblem.php?pid4409 赛后才过只能说悲剧了&#xff0c;知道思路&#xff0c;stl不熟悉&#xff0c;所以导致写的很慢....占据了很多时间&#xff0c;手速代码准确度。。哎。。。 题意&#xff1a; 给你一个家谱&#xff0c;n个人的姓名&#xff0c…

mysql杂记

1、 mysql安装完成后需要将mysql里面的bin目录加到环境变量里之后&#xff0c;才能在cmd窗口里使用mysql命令 2、 在CMD命令窗口敲入命令 mysql -hlocalhost -uroot -ppassword进入mysql数据库 这里我的用户名是root&#xff0c;密码是123456 转载于:https://www.cnblogs.com/y…