VBA - पाठ फ़ाइलें

आप Excel फ़ाइल भी पढ़ सकते हैं और सेल की सामग्री को VBA का उपयोग करके एक पाठ फ़ाइल में लिख सकते हैं। VBA दो तरीकों का उपयोग करके पाठ फ़ाइलों के साथ काम करने की अनुमति देता है -

  • फ़ाइल सिस्टम ऑब्जेक्ट
  • कमांड लिखें

फ़ाइल सिस्टम ऑब्जेक्ट (FSO)

जैसा कि नाम से पता चलता है, एफएसओ डेवलपर्स को ड्राइव, फ़ोल्डर्स और फाइलों के साथ काम करने में मदद करता है। इस अनुभाग में, हम चर्चा करेंगे कि एफएसओ का उपयोग कैसे करें।

अनु क्रमांक। ऑब्जेक्ट प्रकार और विवरण
1

Drive

ड्राइव एक वस्तु है। ऐसे तरीके और गुण सम्‍मिलित करते हैं जो आपको सिस्टम से जुड़ी ड्राइव के बारे में जानकारी इकट्ठा करने की अनुमति देते हैं।

2

Drives

ड्राइव एक संग्रह है। यह सिस्टम से जुड़ी ड्राइव की एक सूची प्रदान करता है, या तो शारीरिक या तार्किक रूप से।

3

File

फ़ाइल एक वस्तु है। इसमें ऐसी विधियाँ और गुण हैं जो डेवलपर्स को फ़ाइल बनाने, हटाने या स्थानांतरित करने की अनुमति देते हैं।

4

Files

फ़ाइलें एक संग्रह है। यह एक फ़ोल्डर के भीतर निहित सभी फाइलों की एक सूची प्रदान करता है।

5

Folder

फ़ोल्डर एक वस्तु है। यह तरीके और गुण प्रदान करता है जो डेवलपर्स को फ़ोल्डर्स बनाने, हटाने या स्थानांतरित करने की अनुमति देता है।

6

Folders

फोल्डर्स एक संग्रह है। यह एक फ़ोल्डर के भीतर सभी फ़ोल्डरों की एक सूची प्रदान करता है।

7

TextStream

TextStream एक ऑब्जेक्ट है। यह डेवलपर्स को पाठ फ़ाइलों को पढ़ने और लिखने में सक्षम बनाता है।

चलाना

Driveएक ऑब्जेक्ट है, जो किसी विशेष डिस्क ड्राइव या नेटवर्क शेयर के गुणों तक पहुंच प्रदान करता है। निम्नलिखित गुणों द्वारा समर्थित हैंDrive वस्तु -

  • AvailableSpace
  • DriveLetter
  • DriveType
  • FileSystem
  • FreeSpace
  • IsReady
  • Path
  • RootFolder
  • SerialNumber
  • ShareName
  • TotalSize
  • VolumeName

उदाहरण

Step 1- FSO का उपयोग करके स्क्रिप्टिंग के लिए आगे बढ़ने से पहले, हमें Microsoft स्क्रिप्टिंग रनटाइम को सक्षम करना चाहिए। ऐसा ही करने के लिए, टूल → सन्दर्भ में नेविगेट करें जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 2 - "Microsoft स्क्रिप्टिंग रनटाइम" जोड़ें और ठीक पर क्लिक करें।

Step 3 - वह डेटा जोड़ें, जिसे आप टेक्स्ट फाइल में लिखना चाहते हैं और कमांड बटन जोड़ें।

Step 4 - अब यह स्क्रिप्ट का समय है।

Private Sub fn_write_to_text_Click()
   Dim FilePath As String
   Dim CellData As String
   Dim LastCol As Long
   Dim LastRow As Long
  
   Dim fso As FileSystemObject
   Set fso = New FileSystemObject
   Dim stream As TextStream
  
   LastCol = ActiveSheet.UsedRange.Columns.Count
   LastRow = ActiveSheet.UsedRange.Rows.Count
    
   ' Create a TextStream.
   Set stream = fso.OpenTextFile("D:\Try\Support.log", ForWriting, True)
  
   CellData = ""
  
   For i = 1 To LastRow
      For j = 1 To LastCol
         CellData = Trim(ActiveCell(i, j).Value)
         stream.WriteLine "The Value at location (" & i & "," & j & ")" & CellData
      Next j
   Next i
  
   stream.Close
   MsgBox ("Job Done")
End Sub

उत्पादन

स्क्रिप्ट निष्पादित करते समय, सुनिश्चित करें कि आप वर्कशीट के पहले सेल में कर्सर रखते हैं। "D: \ Try" के तहत निम्न स्क्रीनशॉट में दिखाया गया है। Support.log फ़ाइल बनाई गई है।

फ़ाइल के विषय निम्नलिखित स्क्रीनशॉट में दिखाए गए हैं।

कमांड लिखो

एफएसओ के विपरीत, हमें किसी भी संदर्भ को जोड़ने की आवश्यकता नहीं है, हालांकि, हम ड्राइव, फ़ाइलों और फ़ोल्डरों के साथ काम नहीं कर पाएंगे। हम केवल पाठ फ़ाइल में स्ट्रीम जोड़ पाएंगे।

उदाहरण

Private Sub fn_write_to_text_Click()
   Dim FilePath As String
   Dim CellData As String
   Dim LastCol As Long
   Dim LastRow As Long
  
   LastCol = ActiveSheet.UsedRange.Columns.Count
   LastRow = ActiveSheet.UsedRange.Rows.Count
    
   FilePath = "D:\Try\write.txt"
   Open FilePath For Output As #2
  
   CellData = ""
   For i = 1 To LastRow
      For j = 1 To LastCol
         CellData = "The Value at location (" & i & "," & j & ")" & Trim(ActiveCell(i, j).Value)
         Write #2, CellData
      Next j
   Next i
  
   Close #2
   MsgBox ("Job Done")
End Sub

उत्पादन

स्क्रिप्ट निष्पादित करने पर, "write.txt" फ़ाइल "D: \ Try" स्थान पर बनाई गई है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

फ़ाइल की सामग्री को निम्न स्क्रीनशॉट में दिखाया गया है।