Java:CSV 文件易于读/写

新手上路,请多包涵

我正在开发一个需要快速访问 CSV 逗号分隔电子表格文件的程序。到目前为止,我已经能够使用 BufferedReader 轻松读取它。但是,现在我希望能够编辑它读取的数据,然后将其导出回 CSV。

电子表格包含姓名、电话号码、电子邮件地址等。程序列出了每个人的数据,当你点击它们时,它会弹出一个页面,其中包含更详细的信息,也是从 CSV 文件中提取的。在该页面上,您可以编辑数据,我希望能够单击“保存更改”按钮,然后将数据导出回 CSV 中相应的行——或者删除旧的,并附加新的。

我不太熟悉使用 BufferedWriter,或者我应该使用的任何东西。

我开始做的是创建一个名为 FileIO 的自定义类。它包含一个 BufferedReader 和一个 BufferedWriter。到目前为止,它有一个返回 bufferedReader.readLine() 的方法,称为 read()。现在我想要一个名为 write(String line) 的函数。

 public static class FileIO {
    BufferedReader read;
    BufferedWriter write;

    public FileIO (String file) throws MalformedURLException, IOException {
        read = new BufferedReader(new InputStreamReader (getUrl(file).openStream()));
        write = new BufferedWriter (new FileWriter (file));
    }

    public static URL getUrl (String file) throws IOException {
        return //new URL (fileServer + file).openStream()));
                FileIO.class.getResource(file);
    }

    public String read () throws IOException {
        return read.readLine();
    }

    public void write (String line) {
        String [] data = line.split("\\|");
        String firstName = data[0];

        // int lineNum = findLineThatStartsWith(firstName);
        // write.writeLine(lineNum, line);
    }
};

我希望有人知道我该怎么做?

原文由 Rich Young 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 426
2 个回答

与其重新发明轮子,不如看看支持读取和写入 CSV 文件的 OpenCSV 。这是 阅读和写作 的例子

原文由 Reimeus 发布,翻译遵循 CC BY-SA 3.0 许可协议

请考虑 Apache commons csv 。为了快速理解 api,有四个重要的类:

CSV格式

指定 CSV 文件的格式并解析输入。

CSV解析器

根据指定的格式解析 CSV 文件。

CSV打印机

以 CSV 格式打印值。

CSVR记录

从 CSV 文件解析的 CSV 记录。

代码示例: 在此处输入图像描述

单元测试代码: 在此处输入图像描述

原文由 Kevin 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题