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" स्थान पर बनाई गई है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
फ़ाइल की सामग्री को निम्न स्क्रीनशॉट में दिखाया गया है।