我想复制文件内容" 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();
}
}
有人可以帮我解决这个问题吗?
答案 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,但我认为,值得学习它。