问题描述
假设我有一个txt文件:Hello World 我只想在两者之间添加“我的”,以便文件看起来像这样:Hello My World 我试图使用java.nio.channels.FileChannel类来实现此目的,因为您可以查找文件指针。但是当我将文件指针移动到文件的中间并写入文本时,它将替换前面的文本,而不仅仅是向前推。
我的代码:
try{
FileChannel out=FileChannel.open(Paths.get("E:\\trial.txt"),StandardOpenoption.WRITE);
out.position(6);
out.write(ByteBuffer.wrap("My ".getBytes()));
}catch(IOException e){
e.printstacktrace();
}
输出:你好我的身份证
所需输出:你好,我的世界
如您所见,“我的”替换了“很差”,我不想替换任何文本,它应该在文件之间添加“我的”。 我知道我可以通过读取“世界”(在指定位置后保留文本)并创建“我的世界”的ByteBuffer,然后将其写入所需的位置来实现。
这可以完成工作:
try{
FileChannel out=FileChannel.open(Paths.get("E:\\trial.txt"),StandardOpenoption.READ,StandardOpenoption.WRITE);
out.position(6);
ByteBuffer b=ByteBuffer.allocate(20);
b.put("My ".getBytes());
out.read(b);
out.position(6);
b.flip();
out.write(b);
}catch(IOException e){
e.printstacktrace();
}
但是,这样做是否更简单/直接呢?您只需将文件指针设置到特定位置,然后编写代码即可添加文本而不替换现有文本?
解决方法
您可以遍历文件中的所有行并将它们保存在数组中。 然后,您只需要循环浏览,最后在其中打印您的内容即可。
,您可以使用这两种方法
这用于读取文件:
public static List<String> readFile(String filePath) {
List<String> list= new ArrayList<>();
try {
File myObj = new File(filePath);
Scanner myReader = new Scanner(myObj);
while (myReader.hasNextLine()) {
String data = myReader.nextLine();
list.add(data);
}
myReader.close();
} catch (FileNotFoundException e) {
System.out.println("An error occurred.");
e.printStackTrace();
}
return list;
}
这用于写入文件:
public static void write(String filePath,String line) {
try {
final Path path = Paths.get(filePath);
Files.write(path,Arrays.asList(line),StandardCharsets.UTF_8,Files.exists(path) ? StandardOpenOption.APPEND : StandardOpenOption.CREATE);
} catch (final IOException ioe) {
// Add your own exception handling...
}
}
第一个方法返回一个字符串列表。每行都是列表的元素。因此,您可以访问包含要修改的句子的列表元素,然后可以使用循环在文件上写每一行。
public static void main (String[] args){
List<String> lines = readFile(filePath);
lines.get(0) = "Hello My world";
for (String line : lines
) {
write(line,filePath);
}
}
祝你有美好的一天!
,要进行顺序文本读取,应使用Reader,该Reader将使用编码Charset读取二进制数据。
解决方案是将该阅读器包装在扩展FilterReader
的您自己的类中。
所需的代码相当多,覆盖了两种读取方法。可能更好地搜索了一些替代实现(也许是Sed.java)。
,好,所以似乎没有直接的方法可以解决,我知道答案中建议的大多数方法,我只是很好奇知道是否有直接的方法,这似乎是一个非常简单和基本的问题。寻找答案。