जंग - फाइल इनपुट / आउटपुट

कंसोल के लिए पढ़ने और लिखने के अलावा, रस्ट फाइलों को पढ़ने और लिखने की अनुमति देता है।

फ़ाइल संरचना एक फ़ाइल का प्रतिनिधित्व करती है। यह एक प्रोग्राम को फाइल पर रीड-राइट ऑपरेशन करने की अनुमति देता है। फ़ाइल संरचना की सभी विधियाँ io का एक प्रकार लौटाती हैं :: परिणाम गणना।

फ़ाइल संरचना के आमतौर पर उपयोग किए जाने वाले तरीके नीचे दी गई तालिका में सूचीबद्ध हैं -

अनु क्रमांक मापांक तरीका हस्ताक्षर विवरण
1 std :: FS :: फ़ाइल खुला हुआ() पब fn खुला <P: AsRef> (पथ: P) -> परिणाम रीड-ओनली मोड में किसी फ़ाइल को खोलने के लिए ओपन स्टैटिक विधि का उपयोग किया जा सकता है।
2 std :: FS :: फ़ाइल सृजन करना() pub fn create <P: AsRef> (पाथ: P) -> परिणाम स्टेटिक मेथड केवल-राइट मोड में एक फाइल खोलता है। यदि फ़ाइल पहले से मौजूद है, तो पुरानी सामग्री नष्ट हो गई है। अन्यथा, एक नई फ़ाइल बनाई जाती है।
3 std :: FS :: remove_file फ़ाइल को हटाएं() pub fn remove_file <P: AsRef> (पथ: P) -> परिणाम <()> फाइलसिस्टम से एक फाइल को हटाता है। इस बात की कोई गारंटी नहीं है कि फ़ाइल को तुरंत हटा दिया गया है।
4 std :: FS :: OpenOptions संलग्न () पब एफएन अपेंडेंड (और म्युट सेल्फ, एपेंड: बूल) -> और म्यूट ओपनऑक्शंस फ़ाइल के एपेंड मोड के लिए विकल्प सेट करता है।
5 std :: कब :: लिखता है write_all () fn write_all (और mut self, buf: & [u8]) -> परिणाम <()> इस लेखन में एक संपूर्ण बफ़र लिखने का प्रयास।
6 std :: कब :: पढ़ें read_to_string () fn read_to_string (और mut self, buf: & mut String) -> परिणाम इस स्रोत में EOF तक सभी बाइट्स पढ़ता है, उन्हें buf में जोड़ देता है।

एक फ़ाइल में लिखें

फाइल कैसे लिखें, यह समझने के लिए एक उदाहरण देखते हैं।

निम्न प्रोग्राम एक फ़ाइल बनाता है 'data.txt'। फ़ाइल बनाने के लिए बनाने () विधि का उपयोग किया जाता है। यदि फ़ाइल सफलतापूर्वक बनाई गई है, तो विधि फ़ाइल हैंडल लौटाती है। अंतिम पंक्ति write_all फ़ंक्शन नई बनाई गई फ़ाइल में बाइट्स लिखेगा। यदि कोई भी ऑपरेशन विफल हो जाता है, तो उम्मीद () फ़ंक्शन एक त्रुटि संदेश देता है।

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("\nTutorialsPoint".as_bytes()).expect("write failed");
   println!("data written to file" );
}

उत्पादन

data written to file

एक फ़ाइल से पढ़ें

निम्न प्रोग्राम एक फ़ाइल data.txt में सामग्री को पढ़ता है और इसे कंसोल पर प्रिंट करता है। "ओपन" फ़ंक्शन का उपयोग किसी मौजूदा फ़ाइल को खोलने के लिए किया जाता है। फ़ाइल के लिए एक निरपेक्ष या सापेक्ष पथ एक पैरामीटर के रूप में खुले () फ़ंक्शन को पास किया जाता है। यदि फ़ाइल मौजूद नहीं है, या यदि यह किसी भी कारण से सुलभ नहीं है, तो खुला () फ़ंक्शन अपवाद को फेंकता है। यदि यह सफल होता है, तो ऐसी फ़ाइल के लिए एक फ़ाइल हैंडल "फ़ाइल" चर को सौंपा गया है।

"फ़ाइल" हैंडल के "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
TutorialsPoint

एक फ़ाइल हटाएँ

निम्न उदाहरण फ़ाइल को हटाने के लिए remove_file () फ़ंक्शन का उपयोग करता है। यदि कोई त्रुटि होती है, तो उम्मीद () फ़ंक्शन कस्टम संदेश देता है।

use std::fs;
fn main() {
   fs::remove_file("data.txt").expect("could not remove file");
   println!("file is removed");
}

उत्पादन

file is removed

डेटा को एक फ़ाइल में जोड़ें

एपेंड () फ़ंक्शन फ़ाइल के अंत में डेटा लिखता है। यह नीचे दिए गए उदाहरण में दिखाया गया है -

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("\nTutorialsPoint".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 के रूप में निष्पादित करें । फ़ाइल को निष्पादित करते समय दो कमांड लाइन तर्क दिए गए हैं -

  • स्रोत फ़ाइल का पथ
  • गंतव्य फ़ाइल