热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

二次封装POI实现一行代码导出Excel

引入依赖包org.apache.poipoi

引入依赖包


org.apache.poipoi3.17
org.apache.poipoi-ooxml3.17


自定义Excel注解

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;/*** @author 易水●墨龙吟* @Description* @create 2019-02-25 13:18*/
@Target({ElementType.CONSTRUCTOR, ElementType.METHOD, ElementType.PARAMETER, ElementType.FIELD, ElementType.ANNOTATION_TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelAttribute {// 字段字符码String name() default "";// 字段宽度int width() default 10;boolean sex() default false;}

配合反射和注解实现导出主要逻辑

import com.lehui.molong.config.excel.annotation.ExcelAttribute;
import com.lehui.molong.entity.excel.ApplyInfo;
import org.apache.poi.hssf.usermodel.*;import javax.servlet.http.HttpServletResponse;
import java.io.BufferedOutputStream;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.List;
import java.util.Map;/*** @author 易水●墨龙吟* @Description Excel导出* @create 2019-02-24 15:54*/
public class ExcelUtiles {/*** Excel后缀*/private final static String SUFFIX &#61; "报名表.xls";/*** Excel导出* &#64;param title* &#64;param response* &#64;param entityExcel* &#64;param data*/public static void PrintToExcel(String title, HttpServletResponse response, Class entityExcel, List data) throws UnsupportedEncodingException, IllegalAccessException, NoSuchMethodException, InvocationTargetException {// 实例化HSSFWorkbookHSSFWorkbook workbook &#61; new HSSFWorkbook();// 创建一个Excel表单&#xff0c;参数为sheet的名字HSSFSheet sheet &#61; workbook.createSheet("sheet");Map map &#61; setTitle(workbook, sheet, entityExcel);setData(sheet, data, map);downloadExcel(workbook, response, setFileName(title));}/*** 创建文件名* &#64;param title* &#64;return*/private static String setFileName (String title) throws UnsupportedEncodingException {String newFile &#61; title &#43; SUFFIX;// 防止出现文件名出现乱码return new String(newFile.getBytes("UTF-8"), "ISO-8859-1");}/*** 设置表头* &#64;param workbook* &#64;param sheet* &#64;param entityExcel*/private static Map setTitle(HSSFWorkbook workbook, HSSFSheet sheet, Class entityExcel) {System.out.println("获取到&#xff1a;" &#43; entityExcel.getName() &#43; "类");// 定义一个map存放表头的下标和数据信息Map titleMap &#61; new HashMap<>();Field[] fs &#61; entityExcel.getDeclaredFields();for (int i &#61; 0; i map) throws InvocationTargetException, IllegalAccessException, NoSuchMethodException {// 表头为第0行int rowNum &#61; 1;for (ApplyInfo entity : data) {// 反射获取实体的信息Class clazz &#61; entity.getClass();Field[] fields &#61; clazz.getDeclaredFields();HSSFRow row &#61; sheet.createRow(rowNum);int index &#61; 0;for(Field field : fields) {// 修改权限&#xff0c;可以访问私有属性field.setAccessible(true);String attr &#61; field.getName();// 调用方法的getXXXX 方法获取属性值Method method &#61; clazz.getMethod("get" &#43; attr.substring(0, 1).toUpperCase() &#43; attr.substring(1));// 获取返回值类型String type &#61; method.getAnnotatedReturnType().getType().getTypeName();Proprety proprety &#61; map.get(index);// 判断类型&#xff0c;返回相应的值if(type.equals("java.lang.String")) {row.createCell(index&#43;&#43;).setCellValue((String)method.invoke(entity));} else if (type.equals("java.lang.Integer")) {if(proprety.isSex()) {Integer sex &#61; (Integer)method.invoke(entity);row.createCell(index&#43;&#43;).setCellValue( sex &#61;&#61; 1 ? "男" : "女");}row.createCell(index&#43;&#43;).setCellValue((Integer)method.invoke(entity));}}rowNum&#43;&#43;;}}/*** 浏览器下载* &#64;param workbook* &#64;param response* &#64;param fileName*/private static void downloadExcel (HSSFWorkbook workbook, HttpServletResponse response, String fileName) {try {//清空responseresponse.reset();//设置response的Headerresponse.setHeader("Content-disposition",String.format("attachment; filename&#61;\"%s\"", fileName));response.setContentType("multipart/form-data");response.setCharacterEncoding("UTF-8");OutputStream os &#61; new BufferedOutputStream(response.getOutputStream());//将excel写入到输出流中workbook.write(os);os.flush();os.close();} catch (Exception e) {e.printStackTrace();}}}

字段属性类

import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;/*** &#64;author 易水●墨龙吟* &#64;Description* &#64;create 2019-02-28 21:09*/
&#64;Getter
&#64;Setter
&#64;NoArgsConstructor
&#64;AllArgsConstructor
public class Proprety {private String name;private int width;private boolean sex;}

在实体类上添加注解

import java.io.Serializable;/*** &#64;author 易水●墨龙吟* &#64;Description* &#64;create 2019-02-24 15:40*/&#64;ToString
&#64;AllArgsConstructor
&#64;NoArgsConstructor
&#64;Setter
&#64;Getter
public class ApplyInfo implements Serializable {&#64;ExcelAttribute(name &#61; "申请人")private String applyName;&#64;ExcelAttribute(name &#61; "性别")private Integer applySex;&#64;ExcelAttribute(name &#61; "年龄")private Integer applyYear;&#64;ExcelAttribute(name &#61; "联系方式")private String applyPhone;&#64;ExcelAttribute(name &#61; "学校")private String applySchool;&#64;ExcelAttribute(name &#61; "学历")private String applyEducation;&#64;ExcelAttribute(name &#61; "地址")private String applyAddress;&#64;ExcelAttribute(name &#61; "邮箱")private String applyEmail;&#64;ExcelAttribute(name &#61; "工作经验")private String applyExperience;&#64;ExcelAttribute(name &#61; "教育经历")private String applyEdu;&#64;ExcelAttribute(name &#61; "职位")private String applySchoolDuty;&#64;ExcelAttribute(name &#61; "在荣誉")private String applySchoolHonor;&#64;ExcelAttribute(name &#61; "特长")private String applySpeciality;}

使用

/*** &#64;author 易水●墨龙吟* &#64;Description* &#64;create 2019-02-14 17:44*/
&#64;Controller
&#64;RequestMapping("/admin")
public class JobController {/*** 导出Excel数据表格* &#64;param jobId*/&#64;GetMapping("/job/applyToExcel")public void printToExcel (HttpServletResponse response, &#64;RequestParam("jobId") Integer jobId) throws UnsupportedEncodingException, IllegalAccessException, NoSuchMethodException, InvocationTargetException {// 获取文件名PartTimeJob job &#61; partTimeJobService.selectById(jobId);// 获取需要导出的所有数据List applyInfoData &#61; jobApplyService.getApplyInfoAll(jobId);// 使用ExcelUtiles.PrintToExcel(job.getJobName(), response, ApplyInfo.class, applyInfoData);}
}

在这里插入图片描述

可以关注我的公众号哦&#xff01;感谢大家&#xff01;

在这里插入图片描述


推荐阅读
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 标题: ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • 本文讨论了如何使用Web.Config进行自定义配置节的配置转换。作者提到,他将msbuild设置为详细模式,但转换却忽略了带有替换转换的自定义部分的存在。 ... [详细]
  • EPPlus绘制刻度线的方法及示例代码
    本文介绍了使用EPPlus绘制刻度线的方法,并提供了示例代码。通过ExcelPackage类和List对象,可以实现在Excel中绘制刻度线的功能。具体的方法和示例代码在文章中进行了详细的介绍和演示。 ... [详细]
  • java drools5_Java Drools5.1 规则流基础【示例】(中)
    五、规则文件及规则流EduInfoRule.drl:packagemyrules;importsample.Employ;ruleBachelorruleflow-group ... [详细]
  • 大数据Hadoop生态(20)MapReduce框架原理OutputFormat的开发笔记
    本文介绍了大数据Hadoop生态(20)MapReduce框架原理OutputFormat的开发笔记,包括outputFormat接口实现类、自定义outputFormat步骤和案例。案例中将包含nty的日志输出到nty.log文件,其他日志输出到other.log文件。同时提供了一些相关网址供参考。 ... [详细]
author-avatar
北京城市环境监督主力军
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有