簡體   English   中英

Java CSV讀/寫器問題

[英]Java CSV Reader/Writer Questions

我有一些關於讀取和寫入CSV文件的問題(或者如果有更簡單的替代方法)。

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

現在我不確定CSV讀寫器是否是最好的路線? 我不知道從Java的SQL開始的地方,但是如果有人知道學習這種資源的好資源,那就太好了。

目前,我正在使用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();
}
  }
}

問題:我很難讓作者在CSV文件中添加新行。 純粹出於人類可讀性的目的,沒有什么大不了的。 我不確定如何將數據添加到現有記錄來修改它。 (刪除並再次添加?不確定如何執行此操作)。

謝謝。

您是否考慮過像H2HSQLSQLite這樣的嵌入式數據庫? 它們都可以持久存儲到文件系統中,您將發現一個更靈活的數據存儲區,代碼更少。

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

關於寫作時的換行,javadoc似乎表明作者將會處理這個問題。 只需為每個用戶bean調用writewrite器將自動在每行之間插入換行符。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM