gpt4 book ai didi

Java CSV 读取器/写入器问题

转载 作者:行者123 更新时间:2023-11-29 06:06:40 25 4
gpt4 key购买 nike

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

谢谢。

最佳答案

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

关于Java CSV 读取器/写入器问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8325406/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com