VBA - File Teks

Anda juga dapat membaca File Excel dan menulis konten sel ke dalam File Teks menggunakan VBA. VBA memungkinkan pengguna untuk bekerja dengan file teks menggunakan dua metode -

  • Objek Sistem File
  • menggunakan Perintah Tulis

Objek Sistem File (FSO)

Seperti namanya, FSO membantu pengembang untuk bekerja dengan drive, folder, dan file. Pada bagian ini, kita akan membahas bagaimana menggunakan FSO.

Sr.No. Jenis & Deskripsi Objek
1

Drive

Drive adalah Objek. Berisi metode dan properti yang memungkinkan Anda mengumpulkan informasi tentang drive yang terpasang ke sistem.

2

Drives

Drive adalah Koleksi. Ini memberikan daftar drive yang terpasang ke sistem, baik secara fisik atau logis.

3

File

File adalah Objek. Ini berisi metode dan properti yang memungkinkan pengembang untuk membuat, menghapus, atau memindahkan file.

4

Files

File adalah Koleksi. Ini memberikan daftar semua file yang ada di dalam folder.

5

Folder

Folder adalah Objek. Ini menyediakan metode dan properti yang memungkinkan pengembang untuk membuat, menghapus, atau memindahkan folder.

6

Folders

Folder adalah Koleksi. Ini memberikan daftar semua folder di dalam folder.

7

TextStream

TextStream adalah Objek. Ini memungkinkan pengembang untuk membaca dan menulis file teks.

Mendorong

Driveadalah objek, yang menyediakan akses ke properti dari drive disk atau jaringan bersama tertentu. Properti berikut ini didukung olehDrive objek -

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

Contoh

Step 1- Sebelum melanjutkan ke pembuatan skrip menggunakan FSO, kita harus mengaktifkan Microsoft Scripting Runtime. Untuk melakukan hal yang sama, navigasikan ke Alat → Referensi seperti yang ditunjukkan pada tangkapan layar berikut.

Step 2 - Tambahkan "Microsoft Scripting RunTime" dan Klik OK.

Step 3 - Tambahkan Data yang ingin Anda tulis dalam File Teks dan tambahkan Tombol Perintah.

Step 4 - Sekarang waktunya untuk Script.

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

Keluaran

Saat menjalankan skrip, pastikan Anda menempatkan kursor di sel pertama lembar kerja. File Support.log dibuat seperti yang ditunjukkan pada gambar berikut di bawah "D: \ Coba".

Isi file ditunjukkan pada tangkapan layar berikut.

Tulis Perintah

Tidak seperti FSO, kami TIDAK perlu menambahkan referensi apa pun, namun, kami TIDAK akan dapat bekerja dengan drive, file, dan folder. Kami hanya dapat menambahkan aliran ke file teks.

Contoh

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

Keluaran

Setelah menjalankan skrip, file "write.txt" dibuat di lokasi "D: \ Try" seperti yang ditunjukkan pada gambar layar berikut.

Isi file ditunjukkan pada gambar layar berikut.