Bài giảng Cơ sở lập trình 1 - Chương 9: Kiểu dữ liệu tệp (File)

pptx 32 trang phuongnguyen 3130
Bạn đang xem 20 trang mẫu của tài liệu "Bài giảng Cơ sở lập trình 1 - Chương 9: Kiểu dữ liệu tệp (File)", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên

Tài liệu đính kèm:

  • pptxbai_giang_co_so_lap_trinh_1_chuong_9_kieu_du_lieu_tep_file.pptx

Nội dung text: Bài giảng Cơ sở lập trình 1 - Chương 9: Kiểu dữ liệu tệp (File)

  1. Chương 9 KIỂU DỮ LIỆU TỆP (File) Khoa Hệ thống thông tin quản lý Hà Nội – 2013
  2. Nội dung 1 Khái niệm kiểu tệp 2 Các thao tác trên tệp 3 Tệp văn bản 4 Tệp nhị phân 5 Các hàm xử lý tệp 6 Truyền tham số là tệp cho hàm 23/05/2021 Chương 9-Kiểu dữ liệu tệp 2/32
  3. 1. Khái niệm kiểu tệp o Tệp n Là tập hợp các dữ liệu có liên quan với nhau và có cùng kiểu được nhóm lại với nhau tạo thành một dãy. n Tệp được chứa trong thiết bị nhớ ngoài à Kích thước và số lượng gần như không hạn chế. o Phân loại tệp n Theo cách truy cập o Tệp truy cập tuần tự: việc đọc một phần tử bất kỳ của tệp bắt buộc phải tuần tự đi qua các phần tử trước đó o Tệp truy cập ngẫu nhiên: có thể truy xuất phần tử bất kỳ của tệp thông qua chỉ số thứ tự phần tử trong tệp 23/05/2021 Chương 9-Kiểu dữ liệu tệp 3/32
  4. Khái niệm kiểu tệp (tt) o Phân loại tệp n Theo bản chất dữ liệu o Tệp văn bản: chứa các kí tự trong bảng mã ASCII không kể đến các kí tự điều khiển. Dữ liệu được lưu thành các dòng, mỗi dòng được kết thúc bằng ký tự xuống dòng là CR (Carriage Return – về đầu dòng, mã 10) và LF (Line Feed – xuống dòng, mã 13). Tệp văn bản kết thúc bằng kí tự EOF (End Of File) có mã 26 (Ctrl + Z) Ví dụ: Các tệp văn bản (text) (*.txt) o Tệp nhị phân: các phần tử là các số nhị phân, và chứa khá nhiều dữ liệu có mã là các kí tự điều khiển. Ví dụ: Các tệp chương trình (*.exe, *.com ) 23/05/2021 Chương 9-Kiểu dữ liệu tệp 4/32
  5. Một số khái niệm o Biến tệp n Là biến thuộc kiểu tệp dùng đại diện cho một tệp tin. n Dữ liệu chứa trong tệp được truy xuất thông qua các thao tác với biến tệp. o Con trỏ tệp n Dùng để xác định vị trí của phần tử hiện tại để đọc hoặc ghi dữ liệu trên tệp. n Khi tệp được mở để đọc hoặc ghi thì con trỏ tệp luôn ở vị trí đầu tệp. n Mỗi khi đọc hoặc ghi trên tệp thì con trỏ tệp tự động tăng lên một khoảng theo đúng số byte vừa đọc hoặc ghi trên tệp. 23/05/2021 Chương 9-Kiểu dữ liệu tệp 5/32
  6. 2. Các thao tác trên tệp o Các bước cơ bản để xử lý tệp 1.Khai báo biến tệp 2.Mở tệp để ghi hoặc đọc 3.Xử lý dữ liệu trong tệp 4.Đóng tệp o Các hàm thao tác với tệp trong thư viện stdio.h 23/05/2021 Chương 9-Kiểu dữ liệu tệp 6/32
  7. 2.1 Khai báo biến tệp o Cú pháp FILE * ; n Trong đó, FILE là từ khoá luôn phải có và viết dạng chữ hoa n Các biến tệp là các biến con trỏ o Ví dụ: FILE *f1,*f2; // Khai báo 2 biến tệp f1 và f2 23/05/2021 Chương 9-Kiểu dữ liệu tệp 7/32
  8. 2.2 Mở tệp o Cú pháp =fopen( , ); n Trong đó: o Tên tệp: đường dẫn đến tệp trên đĩa (lưu ý, dấu \ được ghi là \\). Tên tệp được đặt theo quy tắc đặt tên. o Kiểu xử lý tệp: xác định cách thức mà tệp được mở n fopen trả về một con trỏ tệp, nếu có lỗi con trỏ trả về NULL o Ví dụ: f1=fopen(“C:\\TC\\VIDU.TXT”,”w”); Mở tệp VIDU.TXT mới để ghi f2=fopen(“C:\\TC\\VIDU.TXT”,”r”); Mở tệp VIDU.TXT mới để đọc 23/05/2021 Chương 9-Kiểu dữ liệu tệp 8/32
  9. Các chế độ xử lý tệp Chế độ Ý nghĩa r Mở tệp văn bản để đọc w Mở tệp văn bản để ghi, ghi đè lên tệp đã có a Mở tệp văn bản và ghi nối vào cuối tệp, chưa có tạo mới r+ Mở tệp văn bản để đọc/ghi w+ Mở tệp văn bản để ghi/đọc, ghi đè lên tệp đã có a+ Mở tệp văn bản hoặc tạo mớiđể đọc và ghi nối vào cuối rb Mở tệp nhị phân để đọc wb Mở tệp nhị phânđể ghi, ghi đè lên tệp đã có ab Ghi nối vào tệp nhị phân r+b Mở ra tệp nhị phân để đọc/ghi w+b Tạo ra tệp nhị phân để đọc/ghi a+b Nối vào hay tạo mới tệp nhị phân 23/05/2021 Chương 9-Kiểu dữ liệu tệp 9/32
  10. Ví dụ mở tệp o Mở tệp VIDU.TXT để ghi FILE *f; f = fopen(“VIDU.txt”, “w”); if (f!=NULL) { /* Các câu lệnh để thao tác với tệp*/ /* Đóng tệp */ } else printf(“Loi – Khong mo duoc tep!”); o Chú ý: n Khi mở tệp để ghi mà tệp đã tồn tại rồi thì tệp đó sẽ bị xoá và được thay bằng tệp khác. n Khi mở tệp để đọc thì tệp đó phải tồn tại, nếu không sẽ có lỗi. 23/05/2021 Chương 9-Kiểu dữ liệu tệp 10/32
  11. 2.3 Các thao tác khác o Hàm đóng tệp fclose( ); n Hàm trả về 0 nếu đóng tệp thành công, trả về EOF nếu có lỗi o Hàm kiểm tra kết thúc tệp hay chưa? feof( ); n Hàm trả về EOF nếu đã hết tập tin, ngược lại trả về 0 o Hàm di chuyển con trỏ tệp về đầu rewind( ); 23/05/2021 Chương 9-Kiểu dữ liệu tệp 11/32
  12. 3. Tệp văn bản o Ghi dữ liệu lên tệp văn bản n putc(ch, f); ghi kí tự ch vào tệp văn bản f, trả về EOF nếu gặp lỗi. n fputs(str,f); ghi xâu str vào tệp văn bản f, trả về 0 nếu str rỗng và trả về EOF nếu gặp lỗi n fprintf(f,chuỗi định dạng, danh sách biểu thức); ghi vào tệp văn bản f các biểu thức với các định dạng được chỉ ra, tương tự hàm printf () 23/05/2021 Chương 9-Kiểu dữ liệu tệp 12/32
  13. Ghi dữ liệu lên tệp văn bản o Ví dụ 1: Ghi một dòng các chữ hoa vào tệp #include #include main() { FILE *f; char c; f=fopen("C:\\sample.txt","w"); do putc(toupper(c=getchar()),f); while (c!='\n'); fclose(f); } o Ví dụ 2: Ghi xâu kí tự vào tệp main() { FILE *f; f=fopen("C:\\vidu.txt","w"); fputs(“Ngon ngu lap trinh C”,f); fclose(f); } 23/05/2021 Chương 9-Kiểu dữ liệu tệp 13/32
  14. Đọc dữ liệu từ tệp văn bản o Các hàm đọc dữ liệu từ tệp văn bản n getc(f); fgetc(f); đọc một kí tự từ tệp văn bản f. Hàm trả về mã ASCII của kí tự nào đó (kể cả EOF) trong tệp f n fgets(str,n,f); đọc một xâu str từ tệp văn bản f cho đến khi gặp kí tự xuống dòng ‘\n’ hoặc kí tự EOF hay đủ n kí tự. n fscanf(f,chuỗi định dạng, danh sách các biến); đọc từ tệp văn bản f các biến theo định dạng, tương tự hàm scanf() 23/05/2021 Chương 9-Kiểu dữ liệu tệp 14/32
  15. Đọc dữ liệu từ tệp văn bản (tt) o Ví dụ 1: Sao chép tệp n Sao chép nội dung tệp sample.txt sang tệp sp.txt main() { FILE *f1,*f2; int ch; f1=fopen("C:\\sample.txt","r"); f2=fopen("C:\\sp.txt","w"); if (f1!=NULL&&f2!=NULL) { ch=fgetc(f1); while (!feof(f1)) { fputc(ch,f2); //ghi vao f2 ch=fgetc(f1); //doc tu f1 } fclose(f1); fclose(f2); } } 23/05/2021 Chương 9-Kiểu dữ liệu tệp 15/32
  16. Đọc dữ liệu từ tệp văn bản (tt) o Ví dụ 2: Đọc từ tệp songuyen.txt một dãy các số nguyên dương, ghi vào tệp ketqua.txt các số nguyên tố có trong dãy đó, cuối cùng ghi ra tổng của các số nguyên tố đó. int main() {FILE *f1,*f2; int n; long tong=0; f1=fopen("C:\\songuyen.txt","r"); f2=fopen("C:\\ketqua.txt","w"); if (f1!=NULL && f2!=NULL) { while (!feof(f1)) { fscanf(f1,"%d",&n); if (ngto(n)) { tong+=n; fprintf(f2,"%d\t",n);} } fprintf(f2,"\nTong la: %ld",tong); fclose(f1); fclose(f2); } } 23/05/2021 Chương 9-Kiểu dữ liệu tệp 16/32
  17. 4. Tệp nhị phân o Ghi dữ liệu lên tệp nhị phân n Hàm fwrite(địa chỉ của khối dữ liệu,kích thước mỗi phần tử, số phần tử,f); n Ghi vào trong tệp f khối dữ liệu có địa chỉ, số lượng và kích thước của mỗi phần tử. n Giá trị trả về là số phần tử đã được ghi vào tệp n Ví dụ: FILE *f; int i; f=fopen(“C:\\SN100.txt”,”wb”); for (i=1;i<=100;i++) fwrite(&i,sizeof(int),1,f); fclose(f); 23/05/2021 Chương 9-Kiểu dữ liệu tệp 17/32
  18. Tệp nhị phân (tt) o Đọc dữ liệu từ tệp nhị phân n Hàm fread(địa chỉ của vùng nhớ nhận dữ liệu,kích thước mỗi phần tử, số phần tử,f); n Đọc từ tệp f số lượng phần tử có kích thước của mỗi phần tử được chỉ ra và lưu vào vùng nhớ nhận dữ liệu n Giá trị trả về là số phần tử đã được đọc từ tệp n Ví dụ: g=fopen(“C:\\SN100.txt”,”rb”); do { fread(&i,sizeof(int),1,g); if (!feof(g)) printf(“%d”,i); } while (!foef(g)); 23/05/2021 Chương 9-Kiểu dữ liệu tệp 18/32
  19. Di chuyển con trỏ tệp o Hàm fseek fseek(f,No*Kích thước, vị trí) Trong đó: o f: con trỏ tệp o No: số thứ tự phần tử trong tệp (phần tử đầu tiên đánh số là 0 o Vị trí có thể là: n SEEK_SET hoặc 0: di chuyển từ đầu tệp n SEEK_CUR hoặc 1: di chuyển từ vị trí hiện tại n SEEK_END hoặc 2: di chuyển từ cuối tệp n Hàm trả về 0 nếu di chuyển thành công, trả về khác 0 nếu ngược lại. 23/05/2021 Chương 9-Kiểu dữ liệu tệp 19/32
  20. Di chuyển con trỏ tệp (tt) o Ví dụ: Truy cập trực tiếp để cập nhật dữ liệu main() { FILE *f; int no,number; f=fopen("C:\\SN100.txt","r+b"); do { printf("Vi tri can cap nhat: "); scanf("%d",&no); printf("Gia tri can cap nhat: "); scanf("%d",&number); if (no>0) {fseek(f,sizeof(int)*(no-1),SEEK_SET); fwrite(&number,sizeof(int),1,f);} } while (no!=0); fclose(f); 23/05/2021 Chương 9-Kiểu dữ liệu tệp 20/32
  21. Ví dụ - Quản lý sinh viên o Viết chương trình quản lý sinh viên n Mỗi sinh viên cần quản lý ít nhất 2 thông tin: mã sinh viên và họ tên. n Viết chương trình cho phép lựa chọn các chức năng: o Nhập danh sách sinh viên từ bàn phím rồi ghi lên tập tin SinhVien.dat o Đọc dữ liệu từ tập tin SinhVien.dat rồi hiển thị danh sách lên màn hình o Tìm kiếm họ tên của một sinh viên nào đó dựa vào mã sinh viên nhập từ bàn phím. 23/05/2021 Chương 9-Kiểu dữ liệu tệp 21/32
  22. Ví dụ - Quản lý sinh viên (tt) #include #include #include typedef struct { char Ma[10]; char HoTen[40]; } SinhVien; void WriteFile(char *FileName) { FILE *f; int n,i; SinhVien sv; f=fopen(FileName,"wb"); printf("Nhap bao nhieu sinh vien?"); scanf("%d",&n); fflush(stdin); 23/05/2021 Chương 9-Kiểu dữ liệu tệp 22/32
  23. Ví dụ - Quản lý sinh viên (tt) for(i=1;i<=n;i++) { printf("Sinh vien thu %i\n",i); printf(" - MSSV: ");gets(sv.Ma); printf(" - Ho ten: ");gets(sv.HoTen); fwrite(&sv,sizeof(sv),1,f); fflush(stdin); } fclose(f); printf("Bam phim bat ky de tiep tuc"); getch(); } void ReadFile(char *FileName) { FILE *f; SinhVien sv; f=fopen(FileName,"rb"); printf(" MSSV | Ho va ten\n"); printf(" \n"); 23/05/2021 Chương 9-Kiểu dữ liệu tệp 23/32
  24. Ví dụ - Quản lý sinh viên (tt) fread(&sv,sizeof(sv),1,f); while (!feof(f)) { printf(" %s | %s\n",sv.Ma,sv.HoTen); fread(&sv,sizeof(sv),1,f); } fclose(f); printf("Bam phim bat ky de tiep tuc!!!"); getch(); } void Search(char *FileName) { char MSSV[10]; FILE *f; int Found=0; SinhVien sv; fflush(stdin); printf("Ma so sinh vien can tim: ");gets(MSSV); f=fopen(FileName,"rb"); 23/05/2021 Chương 9-Kiểu dữ liệu tệp 24/32
  25. Ví dụ - Quản lý sinh viên (tt) while (!feof(f) && Found==0) { fread(&sv,sizeof(sv),1,f); if (strcmp(sv.Ma,MSSV)==0) Found=1; } fclose(f); if (Found == 1) printf("Tim thay SV co ma %s. Ho ten la: %s",sv.Ma,sv.HoTen); else printf("Tim khong thay sinh vien co ma %s",MSSV); printf("\nBam phim bat ky de tiep tuc!!!"); getch(); } 23/05/2021 Chương 9-Kiểu dữ liệu tệp 25/32
  26. Ví dụ - Quản lý sinh viên (tt) int main() { int c; for (;;) { printf("\n1. Nhap DSSV\n"); printf("2. In DSSV\n"); printf("3. Tim kiem\n"); printf("4. Thoat\n"); printf("Ban chon 1, 2, 3, 4: "); scanf("%d",&c); if(c==1) WriteFile("d:\\SinhVien.Dat"); else if (c==2) ReadFile("d:\\SinhVien.Dat"); else if (c==3) Search("d:\\SinhVien.Dat"); else break; } return 0; } 23/05/2021 Chương 9-Kiểu dữ liệu tệp 26/32
  27. 5. Các hàm xử lý tệp o int ferror(FILE *fp) n Trả về 0 nếu không có lỗi, khác 0 nếu gặp lỗi o int remove(char *filename) n Xoá tệp có tên là filename n Trả về 0 nếu thành công o int rename(char *old, char *new) n Đổi tên cũ old thành tên mới new n Trả về 0 nếu đổi thành công o int fflush(FILE *fp) n Đổ bộ nhớ đệm o long ftell(FILE *fp) n Cho kích thước của tệp fp 23/05/2021 Chương 9-Kiểu dữ liệu tệp 27/32
  28. 6. Truyền tham số là tệp cho hàm o Ví dụ 1. Sao chép 2 tệp #include #include main(int argc, char *argv[]) { FILE *in,*out; char ch; if (argc!=3) {printf("Chua co ten tep.\n"); exit(1);} if ((in=fopen(argv[1],"rb"))==NULL) {printf("Khong the mo tep nguon!\n");exit(1);} if ((out=fopen(argv[2],"wb"))==NULL) {printf("Khong the mo tep dich!\n");exit(1);} while (!feof(in)) { ch=getc(in); if (!feof(in)) putc(ch,out); } printf("Da sao chep xong!") fclose(in); fclose(out); } 23/05/2021 Chương 9-Kiểu dữ liệu tệp 28/32
  29. Truyền tham số là tệp cho hàm (tt) o Ví dụ 2: Xoá tệp #include #include #include main(int argc, char *argv[]) { char ch; if (argc!=2) {printf("Chua co ten tep.\n"); exit(1);} printf("Co xoa tep %s khong? (C/K)?",argv[1]); ch=getchar(); if (toupper(ch)=='C') if (remove(argv[1])) {printf("Khong the xoa!"); exit(1);} } 23/05/2021 Chương 9-Kiểu dữ liệu tệp 29/32
  30. Truyền tham số là tệp cho hàm (tt) Cách truyền tham số khi thực hiện chương trình o Ví dụ 1: n Dịch ra tệp mycopy.exe n mycopy Chẳng hạn: mycopy sample.txt vd.txt o Ví dụ 2: n Dịch ra tệp mydel.exe n mydel Chẳng hạn: mydel sample.txt 23/05/2021 Chương 9-Kiểu dữ liệu tệp 30/32
  31. Bài tập thực hành 1. Viết chương trình đếm số chữ của từng loại chữ trong bảng chữ cái được chứa trong một tệp văn bản (tệp có bao nhiêu chữ ‘A’, chữ ‘B’ ). 2. Viết chương trình đếm trong tệp văn bản n Có bao nhiêu dòng? n Có bao nhiêu kí tự? n Dòng dài nhất là dòng nào? n Từ dài nhất trong văn bản là từ nào (từ là một nhóm các kí tự liền nhau). 23/05/2021 Chương 9-Kiểu dữ liệu tệp 31/32
  32. Bài tập thực hành 3. Viết chương trình nhập vào từ tệp văn bản songuyen.txt một dãy các số nguyên, hãy tạo ra các tệp: n prime.txt chứa các số nguyên tố có trong dãy n cp.txt chứa các số chính phương n dep.txt chứa các số đẹp (vd: 123, 134 ) n hoanhao.txt chứa các số hoàn hảo 4. Cho 2 tệp So1.txt và So2.txt chứa các số nguyên. n Sắp xếp theo chiều tăng dần các số trong 2 tệp n Tạo tệp So3.txt gồm các số trong cả 2 tệp trên và cũng được sắp theo thứ tự tăng dần. 23/05/2021 Chương 9-Kiểu dữ liệu tệp 32/32