如何将文件的内容复制到另一个文件,但是在Java的文件顶部

时间:2015-02-24 08:12:06

标签: java file filereader fileinputstream filewriter

我想复制文件内容" Convert.sql"提交" Entity.sql"没有覆盖" Entity.sql"文件。这部分我已经能够做到了,但除此之外,我希望文件的内容" Convert.sql"被复制在" Entity.sql"的顶部文件,也不在同一行。

例如:Convert.sql

学生

员工

例如:Entity.sql

名称

地址

例如:结果

学生

员工

名称

地址

以下是我的代码,可以将文件内容复制到另一个文件而不会覆盖该文件,但会将其复制到我不想要的同一行。

package Final;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;

public class Mainy {
    public static void main(String[] args) throws IOException {
        File dir = new File(".");

        String source = dir.getCanonicalPath() + File.separator + "Convert.sql";
        String dest = dir.getCanonicalPath() + File.separator + "Entity.sql";

        File fin = new File(source);
        FileInputStream fis = new FileInputStream(fin);
        BufferedReader in = new BufferedReader(new InputStreamReader(fis));

        FileWriter fstream = new FileWriter(dest, true);
        BufferedWriter out = new BufferedWriter(fstream);

        String aLine = null;
        while ((aLine = in.readLine()) != null) {
            //Process each line and add output to Dest.txt file
            out.write(aLine);
            out.newLine();
        }

        // do not forget to close the buffer reader
        in.close();

        // close buffer writer
        out.close();
    }
}

有人可以帮我解决这个问题吗?

3 个答案:

答案 0 :(得分:1)

这是一个代码片段,可以完成您描述的工作

Charset usedCharset = Charset.defaultCharset();

// read all lines from Convert.sql into a list
List<String> allLines = Files.readAllLines(Paths.get("Convert.sql"), usedCharset);

// append all lines from Entity.sql to the list
allLines.addAll(Files.readAllLines(Paths.get("Entity.sql"), usedCharset));

// write all lines from the list to file Entity.sql
Files.write(Paths.get("Entity.sql"), allLines, usedCharset);

答案 1 :(得分:0)

使用FileWriter(file,true)附加到文件

File file=new File("Entity.sql");
FileWriter fileWritter = new FileWriter(file.getName(),true);
BufferedWriter bufferWritter = new BufferedWriter(fileWritter);

然后读取Convert.sql并写入数据

bufferWritter.write(data);

然后关闭bufferWritter

bufferWritter.close();

答案 2 :(得分:0)

如果你想处理整个文件,根本不需要处理行或将内容解释为文本(即应用字符编码):

Path in=Paths.get("Convert.sql"), out=Paths.get("Entity.sql");
byte[] old=Files.readAllBytes(out);
Files.copy(in, out, StandardCopyOption.REPLACE_EXISTING);
Files.write(out, old, StandardOpenOption.APPEND);

只需as others said,读取您想要完全添加的文件,复制其他文件并附加您在​​第一步中读取的旧数据。

这使用Java 7 API,但我认为,值得学习它。