使用 OpenCSV 將 CSV 對應到 JavaBean
CSV檔案基本上是以逗號分隔的欄位儲存資料的純文字檔案。 OpenCSV是解析這些CSV檔案的函式庫,否則很難處理。它是一個非常易於使用的庫,支援讀寫帶有標題的CSV檔案等多個功能。
在本文中,我們將討論透過OpenCSV將CSV檔案對應到JavaBeans的過程。此外,OpenCSV是一個在這個過程中有幫助的工具。
將 CSV 對應到 JavaBean
OpenCSV庫提供了一些類別和映射策略,用於將CSV檔案對應到Java Beans。其中一個類別是CSVToBean,用於將CSV檔案對應到JavaBeans。要解析這些CSV文件,CSVToBean類別需要定義並傳遞給CSVToBean類別的映射策略。其中一個流行的映射策略是HeaderColumnNameTranslateMappingStrategy,它將列ID對應到Java Bean屬性。
文法
CSV 檔案到 Bean 的對應是透過一系列步驟完成的。然而,建立具有列 ID 和梁屬性之間的對應的 HashMap 的語法如下 -
HashMap map = new HashMap(); map.put("column_id", "bean_property");
首先,我們建立了一個 hashmap,然後使用 HashMap 的 put() 函數將列 id 與對應的 Java bean 屬性進行對應。
演算法
第一步 - 首先使用以下相依性將OpenCSV加入Java專案中。
對於 Maven 項目,將以下相依性新增至 java 項目 -
<dependency> <groupId>com.opencsv</groupId> <artifactId>opencsv</artifactId> <version>4.1</version> </dependency>
對於一個Gradle項目,你需要加入以下依賴項 -
compile group: 'com.opencsv', name: 'opencsv', version: '4.1'
第 2 步 - 現在,讓我們開始將 csv 檔案對應到 Java Bean 的基本步驟。
步驟 3 - 使用列 ID 和 bean 屬性之間的對應建立一個 HashMap。
步驟 4 - 新增與 bean 屬性對應的 csv 檔案的所有欄位 id。
步驟 5 − 建立 HeaderColumnNameTranslateMappingStrategy 物件。
第 6 步 - 現在,將映射的雜湊圖傳遞給 setColumnMapping() 方法。
第 7 步 - 呼叫 CSVToBean 和 CSVReader 類別的物件。
第8步 - 現在,我們將呼叫CSVToBean類別的解析方法,並將HeaderColumnNameTranslateMappingStrategy和CSVReader物件傳遞給它。
第 9 步 - 列印 Bean 物件的詳細資訊。
方法
現在,讓我們使用OpenCSV將Employee.csv檔案的內容對應到JavaBeans。 Employee.csv檔案包含員工姓名、部門和薪水等資料。
Employee.csv檔案的內容如下:
Employee_Name, Department, Salary Naman, Human Resource, 45000 Nikita, Sales, 35000 Rocky, IT, 50000 Raman, Human Resource, 42000
現在,讓我們先建立 Employee 類,然後建立將該 csv 檔案的內容對應到 JavaBeans 的 main 方法。
範例:Employee.java
public class Employee { private static final long serialVersionUID = 1L; public String emp_name, department, salary; public String getName() { return emp_name; } public void setName(String n) { emp_name = n; } public String getSalary() { return salary; } public void setSalary(String s) { salary = s; } public String getDepartment() { return department; } public void setDepartment(String d) { d = department; } public String toString() { return "Employee [Name=" + emp_name + ", Department= " + department +", Salary = " + salary+ "]"; } }
以下是CsvToBean.java檔案的程式碼。
範例
import java.util.*; import com.opencsv.CSVReader; import com.opencsv.bean.CsvToBean; import com.opencsv.bean.HeaderColumnNameTranslateMappingStrategy; public class csvtobean { public static void main(String[] args) { Map<String, String> map = new HashMap<>(); map.put("Employee_Name", "emp_name"); map.put("Department", "department"); map.put("Salary", "salary"); HeaderColumnNameTranslateMappingStrategy<Employee> s = new HeaderColumnNameTranslateMappingStrategy<>(); s.setType(Employee.class); s.setColumnMapping(map); CSVReader csvReader = null; try { csvReader = new CSVReader(new FileReader ("D:\CSVFiles\Employee.csv")); } catch (FileNotFoundException e) { e.printStackTrace(); } CsvToBean csvToBean = new CsvToBean(); List<Employee> l = csvToBean.parse(s, csvReader); for (Employee x : l) { System.out.println(x); } } }
輸出
Employee [Name=Naman, Department=Human Resource, Salary=45000] Employee [Name=Nikita, Department=Sales, Salary=35000] Employee [Name=Rocky, Department=IT, Salary=50000] Employee [Name=Raman, Department=Human Resource, Salary=42000]
如您在上述程式碼中所見,我們首先建立了一個哈希映射,將列ID與對應的bean屬性進行映射。然後,我們為Employee類別實作了HeaderColumnNameTranslateMappingStrategy策略,並將其傳遞給CsvToBean類別的parse方法,以使用OpenCSV將CSV對應到JavaBean。
結論
在本文中,我們研究如何使用 OpenCSV 將 CSV 檔案對應到 JavaBean。所討論的執行此操作的簡單技術是使用 CsvToBean 類別和傳遞給 CsvToBean 類別的物件的映射策略。我們討論了使用 OpenCSV 將 csv 格式的員工資料解析為 JavaBean 的步驟和程式碼。
以上是使用 OpenCSV 將 CSV 對應到 JavaBean的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

HashMap在Java中通過哈希表實現鍵值對存儲,其核心在於快速定位數據位置。 1.首先使用鍵的hashCode()方法生成哈希值,並通過位運算轉換為數組索引;2.不同對象可能產生相同哈希值,導致衝突,此時以鍊錶形式掛載節點,JDK8後鍊錶過長(默認長度8)則轉為紅黑樹提升效率;3.使用自定義類作鍵時必須重寫equals()和hashCode()方法;4.HashMap動態擴容,當元素數超過容量乘以負載因子(默認0.75)時,擴容並重新哈希;5.HashMap非線程安全,多線程下應使用Concu

Optional能清晰表達意圖並減少null判斷的代碼噪音。 1.Optional.ofNullable是處理可能為null對象的常用方式,如從map中取值時可結合orElse提供默認值,邏輯更清晰簡潔;2.通過鍊式調用map實現嵌套取值,安全地避免NPE,任一環節為null則自動終止並返回默認值;3.filter可用於條件篩選,滿足條件才繼續執行後續操作,否則直接跳到orElse,適合輕量級業務判斷;4.不建議過度使用Optional,如基本類型或簡單邏輯中其反而增加複雜度,部分場景直接返回nu

處理Java中的字符編碼問題,關鍵是在每一步都明確指定使用的編碼。 1.讀寫文本時始終指定編碼,使用InputStreamReader和OutputStreamWriter並傳入明確的字符集,避免依賴系統默認編碼。 2.在網絡邊界處理字符串時確保兩端一致,設置正確的Content-Type頭並用庫顯式指定編碼。 3.謹慎使用String.getBytes()和newString(byte[]),應始終手動指定StandardCharsets.UTF_8以避免平台差異導致的數據損壞。總之,通過在每個階段

遇到java.io.NotSerializableException的核心解決方法是確保所有需序列化的類實現Serializable接口,並檢查嵌套對象的序列化支持。 1.給主類添加implementsSerializable;2.確保類中自定義字段對應的類也實現Serializable;3.用transient標記不需要序列化的字段;4.檢查集合或嵌套對像中的非序列化類型;5.查看異常信息定位具體哪個類未實現接口;6.對無法修改的類考慮替換設計,如保存關鍵數據或使用可序列化的中間結構;7.考慮改

JavaSocket編程是網絡通信的基礎,通過Socket實現客戶端與服務器間的數據交換。 1.Java中Socket分為客戶端使用的Socket類和服務器端使用的ServerSocket類;2.編寫Socket程序需先啟動服務器監聽端口,再由客戶端發起連接;3.通信過程包括連接建立、數據讀寫及流關閉;4.注意事項包括避免端口衝突、正確配置IP地址、合理關閉資源及支持多客戶端的方法。掌握這些即可實現基本的網絡通信功能。

在Java中,Comparable用於類內部定義默認排序規則,Comparator用於外部靈活定義多種排序邏輯。 1.Comparable是類自身實現的接口,通過重寫compareTo()方法定義自然順序,適用於類有固定、最常用的排序方式,如String或Integer。 2.Comparator是外部定義的函數式接口,通過compare()方法實現,適合同一類需要多種排序方式、無法修改類源碼或排序邏輯經常變化的情況。兩者區別在於Comparable只能定義一種排序邏輯且需修改類本身,而Compar

遍歷Java中的Map有三種常用方法:1.使用entrySet同時獲取鍵和值,適用於大多數場景;2.使用keySet或values分別遍歷鍵或值;3.使用Java8的forEach簡化代碼結構。 entrySet返回包含所有鍵值對的Set集合,每次循環獲取Map.Entry對象,適合頻繁訪問鍵和值的情況;若只需鍵或值,可分別調用keySet()或values(),也可在遍歷鍵時通過map.get(key)獲取值;Java8中可通過Lambda表達式使用forEach((key,value)->

InJava,thestatickeywordmeansamemberbelongstotheclassitself,nottoinstances.Staticvariablesaresharedacrossallinstancesandaccessedwithoutobjectcreation,usefulforglobaltrackingorconstants.Staticmethodsoperateattheclasslevel,cannotaccessnon-staticmembers,
