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はライターがそれを処理することを示しているようです。各ユーザーBeanを呼び出すだけwriteで、ライターは各行の間に改行を自動的に挿入します。

于 2011-11-30T11:52:04.837 に答える