Java CSV阅读器/写入器问题
问题描述:
我有一些关于读取和写入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文件中添加一行新内容。纯粹是为了人类的可读性目的,并不是什么大不了的事情。 我不知道如何将数据添加到现有的记录来修改它。 (删除并再次添加?不知道如何做到这一点)。
谢谢。
答
最简单的解决方案是在应用程序启动时将文件读入内存中结构(例如,列表UserBean
),以便在此内存中结构中添加,删除或修改Bean,并编写整个列表的UserBean
到应用程序关闭时,或当用户选择保存时的文件。
关于编写新行时,javadoc似乎表明作者会照顾到这一点。只需为每个用户bean调用write
,写入程序将自动在每行之间插入换行符。