[發明專利]基于JAVA反射機制的EXCEL文件數據的導出方法及裝置在審
| 申請號: | 202010126823.4 | 申請日: | 2020-02-28 |
| 公開(公告)號: | CN111367976A | 公開(公告)日: | 2020-07-03 |
| 發明(設計)人: | 倪超然 | 申請(專利權)人: | 平安醫療健康管理股份有限公司 |
| 主分類號: | G06F16/25 | 分類號: | G06F16/25;G06F16/22;G06F16/16 |
| 代理公司: | 北京中強智尚知識產權代理有限公司 11448 | 代理人: | 黃耀威 |
| 地址: | 200001 上海市黃浦*** | 國省代碼: | 上海;31 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 基于 java 反射 機制 excel 文件 數據 導出 方法 裝置 | ||
1.一種基于JAVA反射機制的EXCEL文件數據的導出方法,其特征在于,包括:
依據目標EXCEL文件中的待導出數據對應的標題信息,創建自定義注解;
將所述待導出數據對應的實體屬性添加自定義注解;
根據所述自定義注解,通過JAVA的反射機制對所述待導出數據所對應的實體類進行表格數據讀取;
將讀取到的表格數據保存在預設存儲位置中。
2.根據權利要求1所述的方法,其特征在于,所述根據所述自定義注解,通過JAVA的反射機制對所述待導出數據所對應的實體類進行表格數據讀取,具體包括:
獲取所述目標EXCEL文件中所述待導出數據對應的JAVA類對象;
獲取所述JAVA類對象的Field成員變量;
判斷所述Field成員變量對應的實體屬性中是否存在所述自定義注解;
若所述Field成員變量對應的實體屬性中存在所述自定義注解,則獲取存在的所述自定義注解的Name屬性,并調用預設Get函數提取所述Name屬性在所述目標EXCEL文件中對應的Value值,作為所述讀取到的表格數據。
3.根據權利要求2所述的方法,其特征在于,所述獲取所述JAVA類對象的Field成員變量,具體包括:
收集所述JAVA類對象在所述目標EXCEL文件中各自對應所在單元格的標識;
通過收集到的所述單元格的標識,在所述目標EXCEL文件中劃定區域范圍;
查詢所述區域范圍包含的成員變量進行匯總,得到所述Field成員變量。
4.根據權利要求3所述的方法,其特征在于,所述判斷所述Field成員變量對應的實體屬性中是否存在所述自定義注解,具體包括:
采用泛型將所述區域范圍包含的成員變量的變量類型進行參數化,以便獲取所述區域范圍包含的成員變量各自對應實體屬性的屬性標識;
判斷獲取到的屬性標識中是否存在所述自定義注解對應的特定屬性標識;
若獲取到的屬性標識中存在所述特定屬性標識,則確定所述Field成員變量對應的實體屬性中存在所述自定義注解。
5.根據權利要求4所述的方法,其特征在于,所述調用預設Get函數提取所述Name屬性在所述目標EXCEL文件中對應的Value值,具體包括:
獲取在所述目標EXCEL文件中與所述Name屬性對應的標題行,以及所述標題行所對應列的數據值;
根據所述數據值和與其所在單元格的標識,創建鍵值對數據,作為所述Name屬性在所述目標EXCEL文件中對應的Value值。
6.根據權利要求5所述的方法,其特征在于,若所述預設存儲位置為指定的EXCEL文件,則所述將讀取到的表格數據保存在預設存儲位置中,具體包括:
獲取所述指定的EXCEL文件中待存放所述表格數據的目標存放區域;
若所述目標存放區域內存在與所述Name屬性對應的目標標題行,則按照所述Value值中的鍵值對數據,將各個單元格標識對應的數據值依次填入到所述目標存放區域中與所述目標標題行下所在列的對應單元格內;
若所述目標存放區域內不存在與所述Name屬性對應的目標標題行,則在所述目標存放區域中創建所述目標標題行,并按照所述Value值中的鍵值對數據,將各個單元格標識對應的數據值依次填入到所述目標存放區域中與所述目標標題行下所在列的對應單元格內。
7.根據權利要求6所述的方法,其特征在于,所述方法還包括:
將已存放所述表格數據的所述指定的EXCEL文件,以流的形式寫出到前端進行展示。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于平安醫療健康管理股份有限公司,未經平安醫療健康管理股份有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202010126823.4/1.html,轉載請聲明來源鉆瓜專利網。
- 上一篇:接口調用的方法及裝置、計算機設備、存儲介質
- 下一篇:虛擬化方法和裝置





