Rust - 文件输入/输出

  • 简述

    除了读写控制台之外,Rust 还允许读写文件。
    File 结构代表一个文件。它允许程序对文件执行读写操作。File 结构中的所有方法都返回 io::Result 枚举的变体。
    File 结构的常用方法列在下表中 -
    序号 模块 方法 签名 描述
    1 std::fs::File open() pub fn open<P: AsRef>(path: P) -> Result open 静态方法可用于以只读模式打开文件。
    2 std::fs::File create() pub fn create<P: AsRef>(path: P) -> Result 静态方法以只写模式打开文件。如果文件已经存在,则旧内容将被销毁。否则,将创建一个新文件。
    3 std::fs::remove_file remove_file() pub fn remove_file<P: AsRef>(path: P) -> Result<()> 从文件系统中删除文件。无法保证立即删除该文件。
    4 std::fs::OpenOptions append() pub fn append(&mut self, append: bool) -> &mut OpenOptions 设置文件追加模式的选项。
    5 std::io::Writes write_all() fn write_all(&mut self, buf: &[u8]) -> Result<()> 尝试将整个缓冲区写入此写入。
    6 std::io::Read read_to_string() fn read_to_string(&mut self, buf: &mut String) -> Result 读取此源中 EOF 之前的所有字节,并将它们附加到 buf。
  • 写入文件

    让我们看一个例子来理解如何写一个文件。
    以下程序创建一个文件“data.txt”。create() 方法用于创建文件。如果文件创建成功,该方法将返回一个文件句柄。最后一行write_all函数将在新创建的文件中写入字节。如果任何操作失败,expect() 函数将返回错误消息。
    
    use std::io::Write;
    fn main() {
       let mut file = std::fs::File::create("data.txt").expect("create failed");
       file.write_all("Hello World".as_bytes()).expect("write failed");
       file.write_all("\nJC2182".as_bytes()).expect("write failed");
       println!("data written to file" );
    }
    

    输出

    
    data written to file
    
  • 从文件中读取

    以下程序读取文件 data.txt 中的内容并将其打印到控制台。“打开”功能用于打开现有文件。文件的绝对或相对路径作为参数传递给 open() 函数。如果文件不存在,或者由于某种原因无法访问,则 open() 函数会抛出异常。如果成功,则将此类文件的文件句柄分配给“file”变量。
    “file”句柄的“read_to_string”函数用于将该文件的内容读入字符串变量中。
    
    use std::io::Read;
    fn main(){
       let mut file = std::fs::File::open("data.txt").unwrap();
       let mut contents = String::new();
       file.read_to_string(&mut contents).unwrap();
       print!("{}", contents);
    }
    

    输出

    
    Hello World
    JC2182
    
  • 删除文件

    以下示例使用 remove_file() 函数删除文件。如果发生错误,expect() 函数会返回一条自定义消息。
    
    use std::fs;
    fn main() {
       fs::remove_file("data.txt").expect("could not remove file");
       println!("file is removed");
    }
    

    输出

    
    file is removed
    
  • 将数据附加到文件

    append() 函数将数据写入文件末尾。这在下面给出的示例中显示 -
    
    use std::fs::OpenOptions;
    use std::io::Write;
    fn main() {
       let mut file = OpenOptions::new().append(true).open("data.txt").expect(
          "cannot open file");
       file.write_all("Hello World".as_bytes()).expect("write failed");
       file.write_all("\nJC2182".as_bytes()).expect("write failed");
       println!("file append success");
    }
    

    输出

    
    file append success
    
  • 复制文件

    以下示例将文件中的内容复制到新文件中。
    
    use std::io::Read;
    use std::io::Write;
    fn main() {
       let mut command_line: std::env::Args = std::env::args();
       command_line.next().unwrap();
       // skip the executable file name
       // accept the source file
       let source = command_line.next().unwrap();
       // accept the destination file
       let destination = command_line.next().unwrap();
       let mut file_in = std::fs::File::open(source).unwrap();
       let mut file_out = std::fs::File::create(destination).unwrap();
       let mut buffer = [0u8; 4096];
       loop {
          let nbytes = file_in.read(&mut buffer).unwrap();
          file_out.write(&buffer[..nbytes]).unwrap();
          if nbytes < buffer.len() { break; }
       }
    }
    
    将上述程序main.exe data.txt datacopy.txt 执行。执行文件时传递两个命令行参数 -
    • 源文件的路径
    • 目标文件