0

次のコードは、json ファイル (インデント付きで保存) のフォルダーを開き、コンテンツを取得して json にシリアル化し、新しいファイルをファイルに書き込みます。Python で同じコード タスクが機能するため、データではありません。しかし、ここに表示されるさびたバージョン:

extern crate rustc_serialize;
use rustc_serialize::json;
use std::io::Read;
use std::fs::read_dir;
use std::fs::File;
use std::io::Write;
use std::io;
use std::str;


fn write_data(filepath: &str, data: json::Json) -> io::Result<()> {

    let mut ofile = try!(File::create(filepath));
    let encoded: String = json::encode(&data).unwrap();
    try!(ofile.write(encoded.as_bytes()));
    Ok(())
}


fn main() {

    let root = "/Users/bling/github/data/".to_string();
    let folder_path = root + &"texts";
    let paths = read_dir(folder_path).unwrap();

    for path in paths {
        let input_filename = format!("{}", path.unwrap().path().display());
        let output_filename = str::replace(&input_filename, "texts", "texts2");

        let mut data = String::new();
        let mut f = File::open(input_filename).unwrap();
        f.read_to_string(&mut data).unwrap();
        let json = json::Json::from_str(&data).unwrap();

        write_data(&output_filename, json).unwrap();
    }
}

私のコードで既にエラーを見つけましたか、それとも言語の概念が間違っていましたか? rustc-serialize カーゴが間違って使用されていますか。最後に、期待どおりに機能しません-pythonよりも優れています。

± % cargo run --release --verbose                                                                                                                                            
       Fresh rustc-serialize v0.3.16
       Fresh fileprocessing v0.1.0 (file:///Users/bling/github/rust/fileprocessing)
     Running `target/release/fileprocessing`
thread '<main>' panicked at 'called `Result::unwrap()` on an `Err` value: SyntaxError("unescaped control character in string", 759, 55)', ../src/libcore/result.rs:736
Process didn't exit successfully: `target/release/fileprocessing` (exit code: 101)

json のシリアル化が間違っているとエラーがスローされるのはなぜですか?
失敗したオブジェクトを取得できますか? エンコーディングはどうですか?

...コードは正しいですか、それとももう少し経験を積んで明らかな問題がありますか?

4

1 に答える 1