Bài giảng Database System Concepts - 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.

pdf17 trang | Chia sẻ: vutrong32 | Lượt xem: 1156 | Lượt tải: 0download
Bạn đang xem nội dung tài liệu Bài giảng Database System Concepts - Chương 7: Xử lý tập tin với Visual Basic 6.0, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
bangtqh@utc2.edu.vn TIN HỌC ĐẠI CƯƠNG Chương 7: Xử lý tập tin với Visual Basic 6.0 Dùng cho nhóm ngành: Công trình + Cơ khí bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 7.3. Truy xuất file trong VB (tt) Bảng các lệnh VB truy xuất file Tin học đại cương - Chương 7 6 Tên thủ tục Sequential file Random file Binary file Open X X X Close X X X Input # X Line Input # X Print # X Write # X Input() X X Type....EndType X Put X X Get X X bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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: – 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 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 Giá trị nhận được dấu ',' hay dòng trống Empty #NULL# Null #TRUE# hay #FALSE# True hay False #yyyy-mm-dd hh:mm:ss# Ngày/giờ #ERROR errornumber# mã lỗi errornumber "abcdef" chuỗi abcdef 1254.386 giá trị 1254.386 Tin học đại cương - Chương 7 15 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 Kết qủa ghi trên file outputlist chỉ có dấu ',' Dòng trống (CRLF) Null #NULL# Luận lý #TRUE# hay #FALSE# Date #yyyy-mm-dd hh:mm:ss# mã lỗi errornumber #ERROR errornumber# chuỗi abcdef "abcdef" Số Chuỗi miêu tả số dùng dấu ‘.’ Tin học đại cương - Chương 7 17 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn Ví dụ: Chi tiết hàm đếm từ trong file Tin học đại cương - Chương 7 19 bangtqh@utc2.edu.vn 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 trong file filenum. Mode Return Value Random chỉ số record đọc/ghi lầncuối cùng Binary chỉ số byte đọc/ghi lầncuối cùng. 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 bangtqh@utc2.edu.vn 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 trong file filenum. Mode Return Value Random truy xuất lần kế tiếp ở vị trí record này Binary truy xuất lần kế tiếp ở vị trí byte này 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 bangtqh@utc2.edu.vn 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: Tin học đại cương - Chương 7 22 Giá trị Tên hằng VB gợi nhớ Ý 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 7.8. Lệnh sao chép/Xóa file  Lệnh sao chép file – Cú pháp: FileCopy SourcePath, DestPath. – 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"  Lệnh xóa file – Cú pháp: Kill pattern – 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 bangtqh@utc2.edu.vn 7.9. Các lệnh xử lý thư mục  Lệnh tạo thư mục mới Cú pháp: MkDir pathname Ví dụ: MkDir "D:\Temp\VB60"  Lệnh xóa thư mục (rỗng) Cú pháp: RmDir pathname Ví dụ: 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 Cú pháp: ChDir pathname  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 bangtqh@utc2.edu.vn Tin học đại cương - Chương 7 27 bangtqh@utc2.edu.vn Thực hành chương 7 Xử lý tập tin với Visual Basic 6.0 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn 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 bangtqh@utc2.edu.vn Code của ứng dụng xóa file đệ quy Tin học đại cương - Chương 7 31 bangtqh@utc2.edu.vn Code của ứng dụng (tt) Tin học đại cương - Chương 7 32 bangtqh@utc2.edu.vn Code của ứng dụng (tt) Tin học đại cương - Chương 7 33

Các file đính kèm theo tài liệu này:

  • pdfch7_9793.pdf