将多个文件打印到csv

时间:2013-07-15 03:34:50

标签: java string file class

我正在编写一个带有多行文本文件(File对象)的赋值,然后将这些行组合在一起并用逗号分隔它们,如:

File1Line1, File2Line1
File1Line2, File2Line2

我想我只是对如何使用这些文件感到困惑。如何从每个文件中获取第一行(第二行,第三行等),同时还处理具有不同行数的文件?对此概念的任何帮助表示赞赏。

3 个答案:

答案 0 :(得分:1)

就逐行阅读文件而言,在大多数语言中都很容易。这是java中的一个例子:How to read a large text file line by line using Java?

从概念上讲,您应该首先考虑算法,然后编写一些伪代码以进一步探索和理解它。

对于此分配,一个选项是交替读取每行一行,并立即将它们写入csv。第二种选择是将每一行存储在数据结构中,例如数组,并在最后写入,但这对于大文件来说可能是昂贵的。您可以通过多种方式处理不同的文件长度,例如只编写没有相应行的行。这是一些伪代码,基于java:

    FileReader reader1 = FileReader("file1.text")
    FileReader reader2 = FileReader("file2.text")

    while(reader1.hasNextLine() || reader2.hasNextLine()) 
    {
         if(reader1.hasNextLine()) {
         writeToCSV(reader1.nextLine());
         } 
         if(reader2.hasNextLine() {
         writeToCSV(reader2.nextLine());
         }
         writeToCSV("\r\n");
    }

您可以在实际的方法调用中找到大量示例,但首先要了解该算法非常重要。

答案 1 :(得分:0)

如果您确定两个文件的行是一对一映射,那么很容易。

您可以使用两个BuffererReader来读取这两个文件,您只需要迭代其中一个

这样的一些代码:

BufferedReader reader1 = new BufferedReader(new FileReader(new File(pathOfFile1)));
BufferedReader reader2 = new BufferedReader(new FileReader(new File(pathOfFile2)));

BufferedWriter writer = new BufferedWriter(new FileWriter(new File(pathOfOutputCsvFile)));

String lineOfFile1 = null;

while((lineOfFile1 = reader1.readLine()) != null){

  String lineOfFile2 = reader2.readLine();

  //here, lineOfFile1 and lineOfFile2 are the same line number 
  //then some codes for combination
  //...

}

//finally don't forget to close the readers and writer.

如果您无法确定这两个文件中的行是一对一映射,那么您应该将它们全部读入内存并将它们映射到内存中,然后将它们作为CSV文件输出。

答案 2 :(得分:0)

此代码一次只能直接引用RAM中每个文件的1行,这意味着它应该可以处理没有内存异常的大文件。在幕后,可能会占用比你看到的更多的内存,但它仍然不会因大文件而崩溃。

代码通过从每个文件一次读取一行直到所有文件都为空来工作。当文件用完行时,输出一个空字符串。

void assignment(String outputFile, String... filenames){
    PrintWriter writer = new PrintWriter(outputFile, "UTF-8");
    Scanner scanners = new Scanner[filenames.length];
    for(int i=0;i<filenames.length;i++){
        Scanner scanner = new Scanner(new File(filenames[i]));
        scanners[i] = scanner;
    }
    boolean running = true;
    while(running){
        boolean allEmpty = true;
        StringBuilder csvLine = new StringBuilder();
        for(int i=0;i<scanners.lengh;i++){
            if(scanner.hasNextLine()){
                String line = scanner.nextLine();
                csvLine.append(line);
                allEmpty=false;
            }
            if(i!=scanners.length-1) csvLine.append(",");
        }
        if(allEmpty)
            running=false;
        else
        writer.println(csvLine.toString());

    }
    writer.close();
    for(Scanner s : scanners) s.close();
}

用法:

assignment("output.txt","file1.txt","file2.txt","file3.txt","file4.txt");

或者:

String[] args = new String[]{"helloWorld.txt","fun.bin"};
assignment("output2.txt",args);

此代码未经测试,不处理异常。此代码将允许您从行不匹配的文件中读取行,并将它们组合到单个CSV文件中。由于文件不在行,因此只显示空字符串。

这可以让您了解如何准确地完成您的要求。