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.