2011-11-30 121 views
1

我有一些關於讀取和寫入CSV文件的問題(或者如果有更簡單的選擇)。Java CSV閱讀器/寫入器問題

場景: 我需要一個簡單的人員數據庫和一些關於他們的基本信息。我需要能夠添加新條目並在文件中搜索條目。我還需要能夠找到一個條目並對其進行修改(即更改其名稱或填寫當前空白的字段)。

現在我不確定CSV閱讀器/作家是否是最佳路線?我不知道從Java開始如何使用Java,但如果有人知道有一個很好的學習資源,那很好。

目前我使用SuperCSV,我放在一起根據各地一些示例代碼測試項目:

class ReadingObjects { 

// private static UserBean userDB[] = new UserBean[2]; 
private static ArrayList<UserBean> arrUserDB = new ArrayList<UserBean>(); 

static final CellProcessor[] userProcessors = new CellProcessor[] { 
    new StrMinMax(5, 20), 
    new StrMinMax(8, 35), 
    new ParseDate("dd/MM/yyyy"), 
    new Optional(new ParseInt()), 
    null 
}; 

public static void main(String[] args) throws Exception { 
    ICsvBeanReader inFile = new CsvBeanReader(new FileReader("foo.csv"), CsvPreference.EXCEL_PREFERENCE); 
    try { 
     final String[] header = inFile.getCSVHeader(true); 
     UserBean user; 
     int i = 0; 
     while((user = inFile.read(UserBean.class, header, userProcessors)) != null) { 
     UserBean addMe = new UserBean(user.getUsername(), user.getPassword(), user.getTown(), user.getDate(), user.getZip()); 

     arrUserDB.add(addMe); 
     i++; 

     } 
    } finally { 
     inFile.close(); 
    } 

    for(UserBean currentUser:arrUserDB){ 
     if (currentUser.getUsername().equals("Klaus")) { 
      System.out.println("Found Klaus! :D"); 
     } 
    } 

    WritingMaps.add(); 
    } 
} 

與作家類:

class WritingMaps { 

    public static void add() throws Exception { 
ICsvMapWriter writer = new CsvMapWriter(new FileWriter("foo.csv", true), CsvPreference.EXCEL_PREFERENCE); 
try { 
    final String[] header = new String[] { "username", "password", "date", "zip", "town"}; 
    String test = System.getProperty("line.seperator"); 


    // set up some data to write 
    final HashMap<String, ? super Object> data1 = new HashMap<String, Object>(); 
    data1.put(header[0], "Karlasa"); 
    data1.put(header[1], "fdsfsdfsdfs"); 
    data1.put(header[2], "17/01/2010"); 
    data1.put(header[3], 1111); 
    data1.put(header[4], "New York"); 


    System.out.println(data1); 

    // the actual writing 
//  writer.writeHeader(header); 
    writer.write(data1, header); 
//  writer.write(data2, header); 
} finally { 
    writer.close(); 
} 
    } 
} 

問題: 我m正努力讓作者在CSV文件中添加一行新內容。純粹是爲了人類的可讀性目的,並不是什麼大不了的事情。 我不知道如何將數據添加到現有的記錄來修改它。 (刪除並再次添加?不知道如何做到這一點)。

謝謝。

回答

1

最簡單的解決方案是在應用程序啓動時將文件讀入內存中結構(例如,列表UserBean),以便在此內存中結構中添加,刪除或修改Bean,並編寫整個列表的UserBean到應用程序關閉時,或當用戶選擇保存時的文件。

關於編寫新行時,javadoc似乎表明作者會照顧到這一點。只需爲每個用戶bean調用write,寫入程序將自動在每行之間插入換行符。

2

您是否考慮過嵌入式數據庫,如H2,HSQLSQLite?他們都可以堅持到文件系統,你會發現更少的代碼更靈活的數據存儲。