Dùng cho nhóm ngành: Công trình + Cơ khí
Ạ ƯƠ
Ọ
TIN H C Đ I C
NG
Chương 7: Xử lý tập tin với Visual Basic 6.0
Nội dung
1. Cấu trúc tệp (file) 2. Tổng quát về file trong VB 3. Truy xuất file trong VB (Các lệnh/Các hàm) 4. Truy xuất file nhị phân (binary file) 5. Truy xuất file tuần tự (sequence file/text file) 6. Các hàm xác định vị trí truy xuất file 7. Các hàm truy xuất thuộc tính file 8. Lệnh sao chép và xóa file 9. Các lệnh xử lý thư mục
Tin học đại cương - Chương 7 2
7.1. Cấu trúc tập tin (file) Ở cấp độ hệ điều hành, file là danh sách n byte chưa có ngữ nghĩa. Mỗi ứng dụng phải tự quy định cấu trúc cụ thể cho file của mình tạo ra và đọc lại ngữ nghĩa của cấu trúc này
VB cung cấp 3 dạng file khác nhau, ứng với mỗi dạng có
1 cách thức truy xuất dữ liệu tương ứng. – File tuần tự (sequence file) hay file văn bản là danh sách gồm n byte, mỗi byte là 1 ký tự ANSI (vd: file source code của VB *.bas)
– File nhị phân (binary file) là danh gồm n byte nhị phân
chưa có cấu trúc (vd: file word, excel…)
– File truy xuất trực tiếp (random file): là danh sách gồm n record cùng độ dài, mỗi record chứa nhiều trường (field) thông tin
Tin học đại cương - Chương 7 3
7.2. Tổng quát về file trong VB
VB cung cấp cho người lập trình 2 phương pháp để
quản lý file: – Gọi các thủ tục truyền thống như Open, Close,
Input, Write, Get, Put,….. Ta có thể gọi các thủ tục này là các lệnh VB
– Dùng mô hình đối tượng FSO (File System Object). Người lập trình tạo ra đối tượng FileSystemObject rồi mỗi khi cần quản lý hệ thống file sẽ gọi method tương ứng của đối tượng trên
FSO rất thân thiện và dễ dùng nhưng chỉ hỗ trợ cho phép truy xuất file văn bản, chưa hỗ trợ truy xuất file nhị phân và file random
Tin học đại cương - Chương 7 4
7.3. Truy xuất file trong VB
Quy trình truy xuất 1 file trong VB gồm 3 bước
– Mở/tạo file : Gọi thủ tục Open – Lặp truy xuất file: thông qua việc gọi thủ tục Input,
Get, Put, Write... Thường thì mỗi thủ tục chỉ truy xuất 1 đơn vị thông tin rất nhỏ của file nên ta phải lặp nhiều lần cho tới khi hết file, tuy nhiên ta có quyền đọc/ghi toàn bộ nội dung file vào/ra bộ nhớ
– Đóng file: Gọi thủ tục Close
Tin học đại cương - Chương 7 5
7.3. Truy xuất file trong VB (tt)
Bảng các lệnh VB truy xuất file
Tên thủ tục
Sequential file Random file Binary file
X
Open
X
X
X
Close
X
X
X
Input #
X
Line Input #
X
Print #
X
Write #
X
Input()
X
Type....EndType
X
Put
X
X
Get
X
X
Tin học đại cương - Chương 7 6
7.3. Truy xuất file trong VB (tt)
Bảng các function truy xuất file trong VB
– Dir: Duyệt các phần tử thuộc thư mục – FileCopy: Sao chép 1 file thành file mới – FileDateTime: Đọc/hiệu chỉnh ngày giờ sửa file lần cuối – FileLen: xác định độ dài file chưa mở – FreeFile: xác định chỉ số file còn trống để có thể dùng an
toàn
– Loc: Xác định vị trí truy xuất hiện hành trong file – LOF: xác định độ dài file đã mở – Seek: Xác định/thiết lập vị trí truy xuất file – GetAttr: độc thuộc tính file – SetAttr: ghi thuộc tính file
Tin học đại cương - Chương 7 7
7.4. Truy xuất Binary file Mở (open) file nhị phân
Open pathName For Binary As filenumber –Nếu chưa biết cấu trúc của file nên dùng dãy các byte để đọc/ghi dữ liệu ra/vào file nhị phân –Nếu đã biết cấu trúc file nhị phân nên khai báo kiểu dữ liệu mô tả cấu trúc đó rồi khai báo biến có kiểu vừa định nghĩa để chứa thông tin đọc/ghi trên file
Dùng lệnh Seek để dời pointer tới vị trí mong muốn
Seek [#] filenumber, [position], AVariable Dời pointer tới vị trí position, đọc dữ liệu chứa vào biến AVariable. Số byte đọc được = kích cỡ biến AVariable
Tin học đại cương - Chương 7 8
7.4. Truy xuất Binary file (tt) Dùng lệnh Get để đọc dữ liệu
Get [#] filenumber, [position], AVariable Đọc dữ liệu từ vị trí position rồi chứa vào biến AVariable Số byte đọc được = kích thước biến Avariable
Dùng lệnh Put để ghi dữ liệu
Put[#] filenumber, [position], AVariable Ghi dữ liệu trong AVariable vào vị trí position của file Số byte được ghi vào file = kích thước biến Avariable
Dùng lệnh Close để đóng file
Close [#] filenumber
Tin học đại cương - Chương 7 9
Ví dụ truy xuất Binary file Mỗi file thực thi (*.EXE) đều có 1 header dài 32 bytes với các field như sau:
Index
Field
Diễn giải
0
Magic
Chuỗi 2 ký tự magic "MZ"
...
....
Các file khác (không quan tâm)
18h
Offset
Offset tới bảng tái định chương trình stub
– Nếu giá trị field Offset (2 byte) ở offset 18h (24) có giá trị là 40h (60) thì
tương ứng là file executable trên windows (*.exe, *.dll, *.ocx, *.scr, *.drv,....)
– Nếu giá trị field Offset <40h (60) thì là file *.exe chạy trên DOS
Dựa vào header trên, hãy viết một ứng dụng cho phép user chọn đường dẫn đến file bất kỳ rồi kiểm tra tính chất của file đó với kết quả hiển thị – Không phải file executable – File executable chạy trên DOS – File executable chạy trên Windows (*.exe, *.dll, *.ocx, *.scr, *.drv,....)
Tin học đại cương - Chương 7 10
Ví dụ truy xuất Binary file
Giao diện đề nghị cho ứng dụng kiểm tra loại file
Tin học đại cương - Chương 7 11
Ví dụ: Chi tiết hàm kiểm tra phân loại file
Tin học đại cương - Chương 7 12
7.5. Truy xuất Sequence file Mở file text bằng lệnh Open như sau :
Open pathname [Input | Output | Append] As
filenumber [Len=buffersize] –Nếu file được mở ở chế độ Input & chưa tồn tại thì lỗi sai tên file xảy ra. –Nếu file được mở ở chế độ Output | Append & chưa tồn tại thì hệ thống sẽ tạo ra file mới.
Dùng lệnh Line Input để đọc 1 hàng từ text file
Line Input #filenumber, varname Quy ước 1 hàng kết thúc bởi CR - Carriage Return hay CRLF
Tin học đại cương - Chương 7 13
7.5. Truy xuất Sequence file (tt)
Dùng lệnh Input #filenumber, varlist để đọc các chuỗi hay số từ file (được trình bày chi tiết trong slide kế).
Dùng hàm Input (number, [#]filenumber) để đọc1 chuỗi
từ file (được trình bày chi tiết trong slide kế).
Dùng lệnh Write #filenumber, [outputlist] để ghi các
chuỗi hay số ra file (được trình bày chi tiết trong slide kế).
Sau khi đãxử lý xong file, ta dùng lệnh Close [#]filenum
để đóng file lại.
Tin học đại cương - Chương 7 14
Chi tiết về lệnh Input # Cú pháp : Input #filenumber, varlist
trong đó varlist là danh sách các biến chứa giá trị chuỗi hay số cần đọc, các biến trong danh sách được ngăn cách bằng dấu ','.
Cách thứcxử lý dữ liệu trên file nhập:
Dạng dữ liệu trên file dấu ',' hay dòng trống #NULL# #TRUE# hay #FALSE# #yyyy-mm-dd hh:mm:ss# #ERROR errornumber# "abcdef" 1254.386
Giá trị nhận được Empty Null True hay False Ngày/giờ mã lỗi errornumber chuỗi abcdef giá trị 1254.386
Tin học đại cương - Chương 7 15
Chi tiết về hàm Input
Ngoài lệnh Input ở trên, VB cung cấp thêm hàm Input
với cú pháp như sau:
Input number, [#]filenumber
Trong đó number là số ký tự ANSI cần đọc từ filenumber.
Khác với lệnh Input, kết quả trả về của hàm Input gồm mọi kýtự thô trên file kể cả các ký tự điều khiển CR, LF, khoảng trắng, ",", nháy kép...
Chỉ dùng hàm Input trên các file được mở ở chế độ
Input | Binary.
Tin học đại cương - Chương 7 16
Chi tiết về lệnh Write# Cú pháp : Write#filenumber, [outputlist]
trong đó outputlist là danh sách các biểu thức chứa giá trị chuỗi hay số cần ghi, các biểu thức trong danh sách được ngăn cách bằng dấu ','
Cách thứcxử lý ghi dữ liệu ra file :
Kiểu dữ liệu outputlist chỉ có dấu ',' Null Luận lý Date mã lỗi errornumber chuỗi abcdef Số
Kết qủa ghi trên file Dòng trống (CRLF) #NULL# #TRUE# hay #FALSE# #yyyy-mm-dd hh:mm:ss# #ERROR errornumber# "abcdef" Chuỗi miêu tả số dùng dấu ‘.’
Tin học đại cương - Chương 7 17
Ví dụ truy xuất sequence file
Viết ứng dụng cho phép chọn đường dẫn tới 1 text file rồi đếm số từ được chứa trong file này(Mỗi từ là 1 chuỗi ký tự số a-z hoặc số 0-9)
Tin học đại cương - Chương 7 18
Ví dụ: Chi tiết hàm đếm từ trong file
Tin học đại cương - Chương 7 19
7.6. Các hàm xác định vị trí truy xuất file
Hàm Loc (filenum) trả về vị trí truy xuất hiện tại
Return Value chỉ số record đọc/ghi lầncuối cùng chỉ số byte đọc/ghi lầncuối cùng.
trong file filenum. Mode Random Binary Output | Append | Input
chỉ số byte đọc/ghi lầncuối cùng/128
(ít dùng kết quả này)
Ví dụ
Dim MyChar As Byte Open "TestFile" For Binary As #1 ' mở file để đọc/ghi. Do While Not EOF(1) ' lặpcho đếnhết file.
MyChar = Input(1, #1) ' đọc byte kế tiếp. Debug.Print Loc(1) ' hiểnthị vị trí byte vừa được đọc
Loop Close #1 ' đóng file.
Tin học đại cương - Chương 7 20
7.6. Các hàm xác định vị trí truy xuất file (tt)
Hàm Seek(filenum) trả về vị trí truy xuất kế tiếp
Return Value truy xuất lần kế tiếp ở vị trí record này truy xuất lần kế tiếp ở vị trí byte này
trong file filenum. Mode Random Binary Output | Append | Input
vị trí byte đầu tiên là 1, byte kế là 2,....
Ví dụ
Dim MyChar As Byte Open "TestFile" For Binary As #1 ' mở file để đọc. Do While Not EOF(1) ' lặpcho đếnhết file.
MyChar = Input(1, #1) ' đọc byte kế tiếp. Debug.Print Seek(1) ' hiển thị vị trí byte truy xuất lần kế tiếp
Loop Close #1 ' đóng file.
Tin học đại cương - Chương 7 21
7.7. Các hàm truy xuất thuộc tính file
Hàm FileDateTime(pathname)
– Trả về ngày giờ hiệu chỉnh file lần cuối
Hàm GetAttr (pathname)
– Trả về byte thuộc thuộc tính của file. Các bit trong
byte thuộc tính có ý nghĩa như sau: Tên hằng VB gợi nhớ
Giá trị
Ý nghĩa
0
vbNormal
Normal
1
vbReadOnly
Chỉ đọc
2
vbHidden
Ẩn
4
vbSystem
File hệ thống
8
vbVolume
Nhãn đĩa
16
vbDirectory
Thư mục
32
vbArchive
Bị thay đổi từ lần backup cuối
Tin học đại cương - Chương 7 22
7.7. Các hàm truy xuất thuộc tính file (tt)
Hàm SetAttr (pathname, attributes)
– Thiết lập thuộc tính attributes cho file pathname
Ví dụ
If GetAttr ("c:\windows\win.com") And vbReadOnly Then
MsgBox "c:\windows\win.com là file chỉđọc"
End If
‘thiết lập thuộc tính read-only cho file win.com Dim bytFileAttr As Byte bytFileAttr = GetAttr ("c:\windows\win.com") bytFileAttr = bytFileAttr Or vbReadOnly ' phép Or bitwise SetAttr "c:\windows\win.com", bytFileAttr
Tin học đại cương - Chương 7 23
7.7. Các hàm truy xuất thuộc tính file (tt)
Hàm FreeFile [(rangenumber)]
– Trả về số Integer ứng với chỉ số file chưa được dùng. Tham số rangenumber thường không được dùng trong hàm này
Hàm LOF (#filenumber)
– Trả về giá trị kiểu Long ứng với size của file được
mở xác định bởi filenumber
Hàm FileLen (pathname)
– Trả về giá trị kiểu Long ứng với size của file được
xác định bởi pathname
Tin học đại cương - Chương 7 24
7.8. Lệnh sao chép/Xóa file
Lệnh sao chép file
FileCopy SourcePath, DestPath.
– Cú pháp: – Công dụng: Nhân bản file SourcePath tới DestPath. File
được nhân bản không bị mở rồi mới nhân bản.
Ví dụ :
FileCopy "c:\autoexec.bat" "c:\backup\autoexec.bat"
Kill pattern
Lệnh xóa file – Cú pháp: – Công dụng xóa từ 0 đến n file có tên thỏa mãn mẫu
pattern (dùng ký tự * và ? để miêu tả).
Ví dụ:
Kill "c:\windows\*.tmp"
Tin học đại cương - Chương 7 25
7.9. Các lệnh xử lý thư mục Lệnh tạo thư mục mới
Cú pháp: Ví dụ:
MkDir pathname MkDir "D:\Temp\VB60"
Lệnh xóa thư mục (rỗng)
Cú pháp: Ví dụ:
RmDir pathname RmDir "D:\Temp\VB60"
Hàm lấy đường dẫn tới thư mục hiện hành
Cú pháp:
CurDir [(drive)] Lệnh chuyển thư mục hiện hành ChDir pathname
Cú pháp:
Lệnh chuyển ổ đĩa hiện hành
Cú pháp:
ChDrive drive
Hàm duyệt các phần tử trong 1 thư mục
Cú pháp:
Dir[(pattern [, attributes] ) ]
Tin học đại cương - Chương 7 26
Tin học đại cương - Chương 7 27
ự
ươ
Th c hành ch
ng 7
Xử lý tập tin với Visual Basic 6.0
Lab 04 – Ứng dụng xóa file
Hãy thử viết 1 ứng dụng cho phép user xác định mẫu các file cần xóa rồi tìm các file thỏa mãn mẫu qui định và xóa chúng, việc tìm và xóa nên đệ quy từ vị trí mẫu để xóa triệt để.
Thí dụ nếu người dùng nhập pattern c:\*.tmp, ứng dụng sẽ tìm và xóa mọi file *.tmp từ thư mục gốc.
Tin học đại cương - Chương 7 29
Lab 04 – Ứng dụng xóa file (tt)
Giao diện đề xuất của ứng dụng
Tin học đại cương - Chương 7 30
Code của ứng dụng xóa file đệ quy
Tin học đại cương - Chương 7 31
Code của ứng dụng (tt)
Tin học đại cương - Chương 7 32
Code của ứng dụng (tt)
Tin học đại cương - Chương 7 33