1

我有一些关于读取和写入 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 文件中添加新行。纯粹出于人类可读性的目的,没什么大不了的。我不确定如何将数据添加到现有记录以对其进行修改。(删除并再次添加它?不知道该怎么做)。

谢谢。

4

2 回答 2

2

您是否考虑过像H2HSQLSQLite这样的嵌入式数据库?它们都可以持久保存到文件系统,您会发现一个更灵活且代码更少的数据存储。

于 2011-11-30T20:38:24.043 回答
1

最简单的解决方案是在应用程序启动时将文件读入内存结构(UserBean例如 的列表),在此内存结构中添加、删除、修改 bean,然后将整个列表写入UserBean文件应用程序关闭,或者当用户选择保存时。

关于写作时的换行符,javadoc 似乎表明作者会处理这个问题。只需调用write每个用户 bean,编写器就会自动在每行之间插入换行符。

于 2011-11-30T11:52:04.837 回答