国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Java高級特性-注解:注解實現Excel導出功能

開發 后端
注解是 Java 的一個高級特性,Spring 更是以注解為基礎,發展出一套“注解驅動編程”。

[[355260]]

 注解是 Java 的一個高級特性,Spring 更是以注解為基礎,發展出一套“注解驅動編程”。

這聽起來高大上,但畢竟是框架的事,我們也能用好注解嗎?

的確,我們很少有機會自己寫注解,導致我們搞不清楚注解是怎么回事,更別提用好注解了。

既然這樣,我們就從具體的工作出發,開發一個 Excel 導出功能。我相信,你在搞懂這個例子后,就能明白注解是怎么個用法。

Excel 導出-需求拆解

在后臺管理系統中,常常需要把數據導出 Excel 表。

比如,在雙十一過后,銷售部要把商品訂單錄入到 Excel 表,財務部要把支付訂單錄入到 Excel 表,然后各部門匯總分析,最后找個時間討論怎么改善公司的服務。

你想呀,雙十一的訂單成千上萬,靠人工錄入,少說也要花三四天,而且還特別容易出錯。所以,你必須開發 Excel 導出功能。

那么,具體怎么做呢?

上次我們提到,注解想發揮作用,有三個要素:定義、使用、讀取。這次,我們就利用注解的三個特性,來實現 Excel 導出功能,設計過程是這樣的。

第一步,我們要創建不同的 Excel 模型。雙十一過后,銷售部要訂單數據,財務部要支付數據,兩個部門要的 Excel 表肯定也不一樣,這就得幫每個部門創建不同的 Excel 模型,他們拿到想要的數據。

第二步,我們要根據 Excel 模型,來導出 Excel 表。

看到這,你應該明白 Excel 導出的設計過程了。接下來,我們就來一步步實現這個功能。

創建 Excel 模型

創建 Excel 模型,涉及到注解三要素中的定義、使用。

首先,定義 Excel 注解,我們直接看關鍵代碼。 

  1. @Target({ElementType.FIELD})  
  2. @Retention(RetentionPolicy.RUNTIME)  
  3. public @interface ExcelField {  
  4.     /**  
  5.      * 導出字段標題  
  6.      */  
  7.     String title();     
  8.     /**  
  9.      * 導出字段排序(升序)  
  10.      */  
  11.     int sort() default 0;     
  12.     /**  
  13.      * 對齊方式(0:自動;1:靠左;2:居中;3:靠右)  
  14.      */  
  15.     int align() default 0;     

這里用到了兩個元注解@Retention和@Target。@Target代表這個注解只能放在成員變量上;@Retention代表這個注解要加載到 JVM 內存,我們可以用反射來讀取注解。

此外,注解還有 3 個成員變量,分別對應:Excel 的字段標題、字段排序、對齊方式,方便大家微調表格。到了這,定義 Excel 注解就完成了。

接下來,使用注解,我們還是直接看代碼。 

  1. public class OrderModel {  
  2.     @ExcelField(title = "訂單號"align = 2sort = 20 
  3.     private String orderNo;  
  4.     @ExcelField(title = "金額"align = 2sort = 20
  5.     private String amount;   
  6.      // 創建時間  
  7.     private Date createTime;    
  8.      // 省略 getter/setter 方法  

訂單模型有 3 個字段:訂單號、金額、創建時間,但這里注解只加到訂單號、金額上,表示這兩個字段會導出 Excel 表,而創建時間會忽略,你可以看看這副圖片。

至此,我們完成了定義注解、使用注解,得到了一個 Excel 模型。但要想實現導出功能,還必須根據這個模型,生成出 Excel 表。

讀取 Excel 模型

讀取 Excel 模型,涉及到注解三要素中的讀取。 我們需要讀取注解,生成 Excel 表,這主要分成 3 個步驟:初始化 Excel 表對象—>寫入數據到 Excel 表對象—>輸出文件。

第一步,初始化 Excel 表對象。在這一步中,我們要根據 Excel 模型,生成一個 Excel 表對象,要創建這幾個東西:標題、表頭、樣式等等。我們來看代碼。 

  1. public class ExcelExporter {  
  2.     // ...省略無數代碼  
  3.     /***************************** 初始化 Excel 表對象 ****************************/  
  4.     /**  
  5.      * 構造函數  
  6.      * @param title 表格標題,傳“空值”,表示無標題  
  7.      * @param cls   excel模型對象  
  8.      */  
  9.     public ExcelExporter(String title, Class<?> cls) {  
  10.         // 獲取注解list  
  11.         Field[] fs = cls.getDeclaredFields();  
  12.         for (Field f : fs) {  
  13.             ExcelField ef = f.getAnnotation(ExcelField.class); 
  14.             if (ef != null) {  
  15.                 annotationList.add(new Object[]{ef, f});  
  16.             }  
  17.         }  
  18.         annotationList.sort(comparing(o -> ((ExcelField) o[0]).sort()));  
  19.         // 通過注解獲取表頭  
  20.         List<String> headerList = new ArrayList<>();  
  21.         for (Object[] os : annotationList) {  
  22.             String t = ((ExcelField) os[0]).title();  
  23.             headerList.add(t);  
  24.         }  
  25.         // 初始化excel表:創建excel表、添加表標題、創建表頭等等  
  26.         initialize(title, headerList);  
  27.     }  

在初始化的時候,我們先從 Excel 模型對象中讀取注解,獲得一個注解列表;然后,再從注解列表中,讀取 title-字段標題;最后,再初始化 Excel 表對象,包括:創建 Excel 表對象、添加表標題、創建表頭、添加樣式。

第二步,寫入數據到 Excel 表對象。在這一步中,我們要把 Java 的列表數據寫到 Excel 表對象里,讓這些數據能變成 Excel 表的一行行信息。還是來看代碼。 

  1. public class ExcelExporter {  
  2.     /***************************** 初始化 Excel 表對象 ****************************/  
  3.     // ...省略無數代碼  
  4.     /***************************** 寫入數據到 Excel 表對象 ****************************/  
  5.     /**  
  6.      * 寫入數據  
  7.      * @return list 數據列表  
  8.      */  
  9.     public <E> ExcelExporter setDataList(List<E> list) {  
  10.         for (E dataObj : list) {  
  11.             // 添加行  
  12.             Row row = this.addRow();  
  13.             // 獲取數據,并寫入單元格  
  14.             int cellNo = 0 
  15.             for (Object[] os : annotationList) {  
  16.                 // 獲取成員變量的值  
  17.                 Object value = null 
  18.                 try {  
  19.                     value = Reflections.invokeGetter(dataObj, ((Field) os[1]).getName());  
  20.                 } catch (Exception ex) {  
  21.                     log.info(ex.toString());  
  22.                     value = "" 
  23.                 }  
  24.                 if (value == null) {  
  25.                     value = "" 
  26.                 }  
  27.                 // 寫入單元格  
  28.                 ExcelField ef = (ExcelField) os[0];  
  29.                 this.addCell(row, cellNo++, value, ef.align());  
  30.             }  
  31.         }  
  32.         return this;  
  33.     }  

我們先傳入一個數據列表 dataList,然后用循環來遍歷 dataList,在這個循環中,我們不斷把數據寫進 Excel 表對象里,具體操作是:創建了一個空白行,利用注解獲取成員變量里的值,最后寫進 Excel 表的單元格里。

第三步,輸出文件。在這一步中,就是 Excel 表對象變成一個文件,來看下最后的代碼吧。 

  1. public class ExcelExporter {  
  2.     /***************************** 初始化 Excel 表對象 ****************************/  
  3.     // ...省略無數代碼  
  4.     /***************************** 寫入數據到 Excel 表對象 ****************************/  
  5.     // ...省略無數代碼  
  6.     /***************************** 輸出相關 ****************************/  
  7.     /**  
  8.      * 輸出到文件  
  9.      * @param fileName 輸出文件名,加上絕對路徑  
  10.      */  
  11.     public ExcelExporter writeFile(String fileName) throws IOException {  
  12.         FileOutputStream os = new FileOutputStream(fileName);  
  13.         this.write(os);  
  14.         return this;  
  15.     }  

輸出文件就沒什么好說的了,就是指定文件名,然后把文件輸出到指定的地方。

到了這,讀取 Excel 模型就完成了。

當然,讀取 Excel 模型涉及到注解的讀取,這是最難理解的地方,因為讀取注解要用到 Java 另一個高級特性—反射。而且,注解一般是用來簡化業務,如果你對業務沒有深刻的了解,是很難用好的。

限于篇幅,我只講了最核心的代碼,項目的完整代碼放在文末的鏈接上,大家可以好好看看。

寫在最后

注解想發揮作用,有三個要素:定義、使用、讀取。這篇文章利用了注解的三要素,實現了 Excel 導出功能。

這分成兩步。第一步,創建 Excel 模型,這涉及到注解三要素中的定義、使用;第二步,讀取 Excel 模型,這涉及到注解三要素中的讀取。

總之,注解一般用來簡化業務,你要想用好注解,不但得熟練掌握 Java 的高級用法,還得對業務有深刻的理解。 

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2021-12-30 12:30:01

Java注解編譯器

2023-08-26 11:36:31

Java框架Spring

2023-02-03 08:21:30

excelMySQL

2020-09-22 09:41:09

前端

2014-04-15 15:45:22

Java8Java8教程

2023-02-25 10:04:21

JavaExcel導出功能

2023-03-30 16:16:00

Java自定義注解開發

2014-04-15 09:53:54

Java8類型注解

2024-04-28 08:20:52

Controller接口URL

2019-12-24 10:19:44

泛型反射注解

2024-09-02 07:54:36

2012-02-09 10:42:24

Java

2021-03-01 07:55:41

Java annotation注解

2023-02-07 09:17:19

Java注解原理

2023-11-16 12:35:00

Java程序

2021-03-26 09:37:12

Java開發代碼

2023-05-08 08:11:49

@Component使用場景時序圖

2025-05-19 01:00:00

2014-12-24 10:24:55

Java

2011-07-19 09:38:41

一維數組Junit靜態成員
點贊
收藏

51CTO技術棧公眾號

精品国产一区二区三区| 亚洲人成网站影音先锋播放| 福利在线观看| 欧美日本韩国国产| 色婷婷综合久久久久| 色爱区综合激月婷婷| 久久综合狠狠综合久久综合88 | 天天在线女人的天堂视频| 国产精品免费一区豆花| 日韩成人xxxx| 中文字幕精品在线| 欧美激情网友自拍| 日韩精品视频在线免费观看 | 美女在线一区| 久久久国产一区二区三区| 欧美日韩精品一区二区三区蜜桃 | 成人av综合一区| av在线亚洲一区| 轻轻色免费在线视频| www.xxx麻豆| 成人免费观看网站| 性欧美长视频免费观看不卡| 欧美日产国产精品| 亚洲精品乱码久久久久久日本蜜臀| 国产传媒视频在线观看| 日韩福利影视| 国产成+人+日韩+欧美+亚洲| a黄色在线观看| 毛片av在线| 一广人看www在线观看免费视频| 黄色片一级视频| 久久精品日产第一区二区三区乱码| 国产色综合天天综合网| 色噜噜亚洲精品中文字幕| 色综合久久久久久久| 国产精品天干天干在线综合| 国产精品一级黄| 精品亚洲aⅴ乱码一区二区三区| 欧美在线不卡| 成人免费av电影| 国产三级在线免费| 国产成人精品无码播放| 99久久国产综合精品五月天喷水| 国产精品嫩草影院久久久| 久久综合网hezyo| 亚洲精品福利资源站| 中文字幕欧美日韩一区| 国产精品麻豆一区二区| 亚洲成人激情在线| 亚洲一区二区综合| 国产自产高清不卡| 久久99国产精品麻豆| 福利一区二区在线观看| 国产精品不卡| 免费观看成人www动漫视频| 丁香婷婷激情网| 亚洲欧美综合在线精品| 国v精品久久久网| 国产一区二区免费视频| xnxx国产精品| 国产丝袜欧美中文另类| 久久久91精品国产一区二区精品| 日本亚洲欧美天堂免费| 免费在线观看日韩欧美| 亚洲国产va精品久久久不卡综合| 久久精品视频中文字幕| 亚洲午夜精品福利| 在线观看av片| 日韩电影免费观| 麻豆视频观看网址久久| 日本欧美韩国一区三区| 久久精品国产精品亚洲综合| 精品影院一区二区久久久| 黑人精品欧美一区二区蜜桃| 久久综合导航| 久久精品国产99国产| 国产麻豆精品在线观看| 国产裸体歌舞团一区二区| 日韩精品亚洲专区| 精品久久久久久电影| 伊人开心综合网| 欧美一卡2卡3卡4卡| 亚洲精品中文字幕在线| 四虎精品在线| 97久久视频| 成人国产视频在线观看| 国产精品久久久久久一区二区三区| 亚洲黄色小视频| 日韩视频免费观看高清完整版在线观看| 亚洲精品美女在线观看| 欧美猛交免费看| 成人国产精品久久久久久亚洲| 一本一生久久a久久精品综合蜜| 男人操女人免费软件| 交视频在线观看国产| 日韩伦理在线观看| 丁香婷婷成人| 久久99精品国产麻豆婷婷洗澡| 亚洲男人都懂的| 欧美成va人片在线观看| 99久久综合狠狠综合久久止| 免费毛片网站在线观看| 男人的天堂在线播放| caoprom在线| 亚洲无吗一区二区三区| 日本在线视频中文有码| 欧美午夜在线视频| 女人让男人操自己视频在线观看| 日韩精品一二三四区| 亚洲无亚洲人成网站77777| 国产精品小说在线| 日韩伦理一区二区三区av在线| 免费人成在线观看视频播放| 久热久精久品这里在线观看| 在线毛片观看| 另类综合日韩欧美亚洲| 久久蜜桃一区二区| 亚洲国产成人高清精品| 日韩精品视频在线观看网址| 欧美成人精品一区| 免费在线成人av| 成人黄色av片| 欧美婷婷精品激情| 人人干在线视频| 久久综合五月婷婷| 免费在线观看成人| 亚洲欧美怡红院| 欧美sm美女调教| av日韩中文字幕| 久久综合九色综合久| 2019年精品视频自拍| 国产福利91精品一区| 久久精品中文字幕电影| 丝袜人妻一区二区三区| 欧美91在线|欧美| 中文文精品字幕一区二区| 一区二区三区精品| 久久久久久久影院| 欧美18视频| 9191在线| 爱爱精品视频| 亚洲在线成人精品| 国产视频精品网| 欧美片第一页| 亚洲欧洲三级电影| 国产一区二区三区四区五区加勒比| 国产91久久久久蜜臀青青天草二| 少妇久久久久| 国产精品―色哟哟| 国产ts人妖一区二区三区 | 欧美三级午夜理伦三级在线观看| 国精产品一区一区三区mba桃花| 亚洲欧美在线视频观看| 久久精品国产成人| 欧美大香线蕉线伊人久久| 天天夜夜亚洲| 中文字幕一区二区三区中文字幕 | 亚洲77777| 天堂网av成人| 色综合久久综合网欧美综合网| 久久的精品视频| 欧美二区在线视频| 日韩在线观看一区二区三区| 午夜精品福利在线| 国产精品视频大全| 一级毛片视频在线观看| 91精品啪在线观看国产81旧版| 色欧美片视频在线观看| 欧美中文娱乐网| 色呦呦呦在线观看| 午夜在线成人av| 亚洲黄色网址在线观看| 91se在线观看| 激情久久综合| 中文字幕在线日韩 | 久久久不卡网国产精品一区| 九九九久久久久久| 狠狠热免费视频| 亚洲欧洲日韩| 中文字幕亚洲一区二区三区五十路 | 在线精品视频在线观看高清| 亚洲成人av电影在线| 亚洲不卡1区| 一本一道久久a久久| 色悠悠亚洲一区二区| 午夜啪啪免费视频| 女同久久另类99精品国产 | 欧美xoxoxo| 成人午夜视频在线| 狠狠色狠狠色综合日日五| 手机在线免费观看毛片| 亚洲欧美高清| 怡红院精品视频| 国产中文字幕在线观看| 欧美国产97人人爽人人喊| 国产青春久久久国产毛片| 综合中文字幕| 日韩久久午夜影院| 免费在线观看av| 久久精品人人做|