gpt4 book ai didi

java - 在循环java中的多列中写入CSV

转载 作者:行者123 更新时间:2023-11-30 11:20:17 25 4
gpt4 key购买 nike

我正在尝试将两列数组写入 .csv 文件。该数组具有任意数量的列,从几到几千不等。目前我有将单个数组写入 .csv 文件的代码,如下所示。 generateCSV方法中的参数n表示循环中的点,从n=1开始。

public class MakeCSVFile {

public static void generateCSV(File myFile, double[][] ProtonTracking,int n) throws IOException{
PrintWriter pw = new PrintWriter(new FileWriter(myFile));
pw.print(String.format("Trial Number :, %d\n", n));
for(int i= 0; i < Array.getLength(ProtonTracking); i++) {
pw.print(String.format("%f, %f%n", ProtonTracking[i][0], ProtonTracking[i][1]));
}
pw.flush();
pw.close();
}
}

此代码将 n=1 的第一个数组正确写入 .csv 文件。然而,对于循环的下一阶段,当 n=2 时,数组被写入与 n=1 时相同的位置,因此只有最近的 arrray 被保存到 .csv 文件中。我想告诉这个方法在 n=1 等的数组旁边的两列中写 n=2 的数组,这样最后 .csv 文件包含所有 n 的数组。

换句话说,对于 n=2,我想从第 3 列开始写入 .csv 文件,而不是第 1 列。我尝试通过在循环中输入逗号来实现这一点,例如:

for(int k= 0; k<n; k++) {
pw.print(String.format(", ,");
}

但这会覆盖之前所有的列。

最佳答案

这是因为您每次都重新打开文件:

PrintWriter pw = new PrintWriter(new FileWriter(myFile));

当您这样做时,现有文件将被截断并用新数据替换它(默认情况下,FileWriter 以这种方式打开文件)。最简单的选择可能是使用 FileWriter open the file in append mode :

PrintWriter pw = new PrintWriter(new FileWriter(myFile, true));

另一种方法是在写入所有记录之前打开文件一次,然后将 PrintWriter(或 FileWriter)传递给 generateCSV 文件的:

public static void generateCSV(PrintWriter pw, double[][] ProtonTracking,int n) throws IOException{
pw.print(String.format("Trial Number :, %d\n", n));
for(int i= 0; i < Array.getLength(ProtonTracking); i++) {
pw.print(String.format("%f, %f%n", ProtonTracking[i][0], ProtonTracking[i][1]));
}
pw.flush();
// <- note that .close() was removed! don't close until completely done.
}

选择最适合您的应用的选项。


在您提出的评论中:

However, these are all contained vertically one after the other in two columns. Is it possible to display these side by side in many two columns sections?

以您当前的结构,这并不容易。将数据插入 到文件中间通常很重要。您可以想象创建一个方法来加载现有文件的行,将数据附加到每一行,然后写回所有行(性能最终会受到很大影响)。但是,更简洁的方法是以下三种选择之一:

  1. 提前收集您要写入文件的所有数据。甚至可以创建一个小的 Trial 类来保存有关单个试验的信息(这也会使您的代码具有更清晰的语义,从长远来看有助于消除混淆和错误)。然后,当需要写入整个文件时,您可以随意循环访问您认为合适的试验集合,并以您希望的任何顺序写入数据。

  2. 在这里重新定义您的概念。修改您的代码以将给定试验的所有对存储在 单个 行中(您甚至可以将 n 本身存储在第一列中,以及其他有趣的信息,例如时间戳其他栏中的记录等)。 CSV 文件以表格格式存储数据。通常,在表中,每一行是一条记录,每一列是一个字段。我只是在猜测,但在您的应用程序中,“试验”似乎是某种独立的记录,并且每个试验都有一组与之关联的属性(字段)。考虑到这一点,有一个非常宽的表实际上是非常合适的,每个试验作为行,试验的每个数据作为列。这就是为什么,例如,电子表格软件中的图形生成器默认将作为数据字段。

  3. 表格的第一行通常是为标题保留的。在整个表中以一定间隔存储“Trial x”标题是不寻常的。考虑到这一点,也许您应该考虑为每个试验创建一个单独的 CSV 文件。根据n生成文件名。

选项 2 和 3 可能并不总是合适的;例如,您可能会受到某些期望数据采用特定格式的第三方应用程序的限制。然而,如果你有灵 active ,听起来像一个宽表,每个试验一行,或者每个试验单独的文件,是你数据的更自然的表示(当然,也更容易编写)。如果您使用 CSV 的目的只是为了在电子表格程序中任意格式化您的输出以便于人类查看(而不是数据存储/分析),您可能也会发现这些选项不合适。

选项 1,如果这是您的方式,要求您提前提供所有数据(这可能会也可能不会,具体取决于您的应用程序的性质,内存要求等),以便您可以在输出的每一行中“交错”您的试验。

关于java - 在循环java中的多列中写入CSV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22824523/

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