Dan*_*ado 4 iterator loops rust
尝试再次访问变量句子会导致value used here after move,我想了解如何在不导致此问题的情况下存储总数。
我试图复制迭代器,但找不到使其工作的方法或正确的方法。
extern crate regex;
use std::fs::File;
use std::path::Path;
use std::io::{BufReader, BufRead};
fn main() {
let sentences_path = Path::new("csv/testSentences.csv");
let sentences = BufReader::new(File::open(&sentences_path).unwrap());
let total = sentences.lines().count();
for (index, sentence) in sentences.lines().enumerate() {
let line = sentence.unwrap();
println!("Processed {} of {}, {}", index, total, line);
}
println!("Total {}", total);
}
Run Code Online (Sandbox Code Playgroud)
如果之前移动了所有权,您将无法访问该值。然而,你可以用你的线检查在检查不改变内部线,但只更新计数器。
count通过迭代 Lines找出后,您可以再次迭代它并按照您的意愿执行逻辑。
您收到此编译器错误的主要原因是:count函数消耗了您使用的 Lines,并且您无法再次访问您的变量,因为它已经被消耗了。
这是解决方案:
use std::fs::File;
use std::io::{BufRead, BufReader, Write};
fn main() {
let path = "lines.txt";
let mut output = File::create(path).unwrap();
write!(output, "Rust\n\nFun").unwrap();
let input = File::open(path).unwrap();
let buffered = BufReader::new(input);
let lines: Vec<_> = buffered.lines().collect();
let total = lines.len();
for (index, sentence) in lines.into_iter().enumerate() {
let line = sentence.unwrap();
println!("Processed {} of {}, {}", index, total, line);
}
println!("Total {}", total);
}
Run Code Online (Sandbox Code Playgroud)
通过这种方式,您不需要两次读取文件。你只迭代它两次。