前言

上一篇中写到了用反射来处理类中的不用的属性,但是Excel的列名还得手动输入,这样还是比较麻烦的,今天这篇就利用自定义注解来解决手动传入列名的问题;其实很简单的,只需要在上一篇的基础上加一个类就可以了;

本篇所涉及的项目是在上一篇 Excel通用类工具(一) 的项目代码上进行的二次添加;

正文

  1. 新添加一个类

    新添加一个注解类 ExcelName ,完整代码如下:

  1. import java.lang.annotation.ElementType;
  2. import java.lang.annotation.Retention;
  3. import java.lang.annotation.RetentionPolicy;
  4. import java.lang.annotation.Target;
  5. @Target(ElementType.FIELD)
  6. @Retention(RetentionPolicy.RUNTIME)
  7. public @interface ExcelName {
  8. String name() default "";
  9. }

这个类主要就是一个注解,对java的注解还不了解的可以点击这里 传送门,因为只需要知道每个属性得列名,所以只定义了一个属性name,该属性的值就是列名;

  1. 改造实体类 pojoA 和 pojoB ,这一只改造一个类:

    pojoA

  1. public class PojoA {
  2. @ExcelName(name = "名称")
  3. private String name;
  4. @ExcelName(name = "数量")
  5. private int num;
  6. @ExcelName(name = "价格")
  7. private double price;
  8. //省略set/get
  9. }

只需要在每个属性上添加上边的注解就可以了;

  1. 对核心代码进行改造

    改造的代码不多,主要是将类中属性上的注解的值读取出来,放入列名中:

  1. public class ExcelUtil<T> {
  2. public HSSFWorkbook setExcel(String title, List<T> tList) throws NoSuchMethodException, IllegalAccessException, InvocationTargetException, IOException {
  3. Field[] declaredFields = tList.get(0).getClass().getDeclaredFields();
  4. // 1.创建Excel工作薄对象
  5. HSSFWorkbook workbook=new HSSFWorkbook();
  6. // 2.创建Excel工作表对象
  7. HSSFSheet sheet=workbook.createSheet(title);
  8. HSSFRow row=null;
  9. // 3.创建Excel工作表的第一行,并填充列名
  10. row=sheet.createRow(0);
  11. for (int i=0;i<declaredFields.length;i++){
  12. ExcelName excelName = declaredFields[i].getAnnotation(ExcelName.class);
  13. if(excelName!=null){
  14. if(excelName.name()!=null){
  15. row.createCell(i).setCellValue(excelName.name());
  16. }
  17. }else {
  18. row.createCell(i).setCellValue("");
  19. }
  20. }
  21. /* for(int i=0;i<columnNames.length;i++){
  22. row.createCell(i).setCellValue(columnNames[i]);
  23. }*/
  24. // 4.将数据填充至表格中
  25. for(int j=1;j<=tList.size();j++){
  26. T t= tList.get(j-1);
  27. row=sheet.createRow(j);
  28. for(int i=0;i<declaredFields.length;i++){
  29. // 通过反射获取属性值
  30. String fieldName = declaredFields[i].getName();
  31. String getMethodName="get"+fieldName.substring(0,1).toUpperCase()+fieldName.substring(1);
  32. Method declaredMethod = t.getClass().getDeclaredMethod(getMethodName);
  33. //执行方法
  34. Object fieldValue = declaredMethod.invoke(t);
  35. //判断是否为空
  36. if(fieldValue!=null && !"".equals(fieldValue)){
  37. //判断属性值类型
  38. if(fieldValue instanceof Integer){
  39. row.createCell(i).setCellValue(Integer.valueOf(fieldValue.toString()));
  40. }else if(fieldValue instanceof Double){
  41. row.createCell(i).setCellValue(Double.valueOf(fieldValue.toString()));
  42. }else if(fieldValue instanceof Date){
  43. row.createCell(i).setCellValue(new SimpleDateFormat("yyyy-MM-dd hh:mm:ss").format(fieldValue));
  44. }else {
  45. row.createCell(i).setCellValue(fieldValue.toString());
  46. }
  47. }else {
  48. row.createCell(i).setCellValue("");
  49. }
  50. }
  51. }
  52. // 5 .自动设置列宽
  53. for (int i = 0; i < declaredFields.length; i++) {
  54. sheet.autoSizeColumn(i);
  55. sheet.setColumnWidth(i,sheet.getColumnWidth(i)*17/10);
  56. }
  57. return workbook;
  58. }
  59. }

较上一篇笔记来说,主要添加的就是第三部的那一部分代码,而原来那部分就是注释了的那一部分,可以看一下有什么区别;还有就是最后添加了第五步的那一部分代码,需要提醒的是这部分代码需要在数据填充完了之后再调用;

  1. 测试类

    测试还是用上一篇的测试类,这里就不贴出来了;

总结

这篇笔记主要是在上一篇的基础上添加了自定义注解,对注解的了解也进一步加深,但还是有许多的不足之处;

Excel通用类工具(二)的更多相关文章

  1. Excel通用类工具(一)

    前言 最近项目中遇到要将MySQL数据库中的某些数据导出为Excel格式保存,在以前也写过这样的功能,这次就准备用以前的代码,但是看了一下,这次却不一样,因为在以前用到的都是导出一种或几种数据,种类不 ...

  2. MVC NPOI Linq导出Excel通用类

    之前写了一个模型导出Excel通用类,但是在实际应用中,可能不是直接导出模型,而是通过Linq查询后获取到最终结果再导出 通用类: public enum DataTypeEnum { Int = , ...

  3. NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中

    以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...

  4. 转:TestLink1.9.3测试用例:Excel转换XML工具<二>实现代码

    TestLink1.9.3测试用例:Excel转换XML工具<二>实现代码 http://blog.csdn.net/candle806/article/details/7490599 以 ...

  5. C#:导入Excel通用类(CSV格式)

    一.引用插件LumenWorks.Framework.IO.dll(CsvReader) 插件下载地址:https://pan.baidu.com/s/1c3kTKli  提取密码 dz7j 二.定义 ...

  6. C#:导入Excel通用类(Xls格式)

    PS:在CSV格式和XLSX格式中有写到通用调用的接口和引用的插件,所以在这个xls格式里面并没有那么详细,只是配上xls通用类. 一.引用插件NPOI.dll.NPOI.OOXML.dll.NPOI ...

  7. C#:导入Excel通用类(Xlsx格式)

    一.引用插件EPPlus.dll   插件下载地址:https://pan.baidu.com/s/1jEl7iu1H_C7-j9Wq37xIRQ  提取密码:pdy6 二.定义通用类XlsxExce ...

  8. poi导出excel通用类

    一.关键的通用类public class PoiExportUtils {    private static HSSFWorkbook workBook; public PoiExportUtils ...

  9. NPOI MVC 模型导出Excel通用类

    通用类: public enum DataTypeEnum { Int = , Float = , Double = , String = , DateTime = , Date = } public ...

随机推荐

  1. [python] 3 、基于串口通信的嵌入式设备上位机自动测试程序框架(简陋框架)

    星期一, 20. 八月 2018 01:53上午 - beautifulzzzz 1.前言 做类似zigbee.ble mesh...无线网络节点性能测试的时候,手动操作然后看表象往往很难找出真正的原 ...

  2. CLion之C++框架篇-优化开源框架,引入curl,实现get方式获取资源(四)

      背景   结合上一篇CLion之C++框架篇-优化框架,引入boost(三),继续进行框架优化!在项目中,我们经常会通过get方式拉取第三方资源,这一版优化引入类库curl,用来拉取第三方资源库. ...

  3. 剑指offer面试题27:二叉搜索树与双向链表

    题目:输入一颗二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的节点,只能调整树中节点指针的指向. 由于二叉搜索树是有序的,左子结点的值小于根节点的值,右子结点的值大于根节点的值 ...

  4. RestTemplate远程调用POST请求:HTTP 415 Unsupported Media Type

    这是本项目的接口 称为client @POST @Path("/{urlcode}") @Consumes(MediaTypes.JSON_UTF_8) @Produces(Med ...

  5. 爬虫不过如此(python的Re 、Requests、BeautifulSoup 详细篇)

    网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本. 爬虫的本质就是一段自动抓取互联网信息的程序,从网络获取 ...

  6. 一道关于:ArrayList、Vector、LinkedList的存储性能和特性 的面试题

    ArrayList 和Vector是采用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,都允许直接序号索引元素,但是插入数据要设计到数组元素移动等内存操作,所以索引数据快插入数据慢 ...

  7. .NET Core 获取 HttpContext.Current 以及 AsyncLocal 与 ThreadLocal

    在 DotNetCore 当中不再像 MVC5 那样可以通过 HttpContext.Current 来获取到当前请求的上下文. 不过微软提供了一个 IHttpContextAccessor 来让我们 ...

  8. (转)EVMON_FORMAT_UE_TO_TABLES procedure - move an XML document to relational tables

    原文:https://www.ibm.com/support/knowledgecenter/zh/SSEPGG_9.8.0/com.ibm.db2.luw.sql.rtn.doc/doc/r0054 ...

  9. ionic hidden scroll bar

    ionic 项目中隐藏所有的ion-content滚动条 在variables.scss文件中添加以下代码 ::-webkit-scrollbar { display: none; }  

  10. mysql 获取昨天日期、今天日期、明天日期以及前一个小时和后一个小时的时间

    1.当前日期 select DATE_SUB(curdate(),INTERVAL 0 DAY) ; 2.明天日期select DATE_SUB(curdate(),INTERVAL -1 DAY) ...