Presentation is loading. Please wait.

Presentation is loading. Please wait.

Applications with Random File Access CHAPTER 8. C.13 1 Where am I on the Binary File? » While a binary file is processed, it is a need to know current.

Similar presentations


Presentation on theme: "Applications with Random File Access CHAPTER 8. C.13 1 Where am I on the Binary File? » While a binary file is processed, it is a need to know current."— Presentation transcript:

1 Applications with Random File Access CHAPTER 8

2 C.13 1 Where am I on the Binary File? » While a binary file is processed, it is a need to know current position, really which byte is being processed. » The FPI is containing the address of the current byte in the file. » ftell() is the function that can be used to learn the content of the FPI. The syntax of the ftell() is: long ftell(file_pointer); » So, the ftell() function is returning the file position of the current byte in LONG data type.

3 C.13 2 The ftell() Function Example: #include void main() { FILE *fp; long position; fp = fopen(“TEST.TXT”,”rb”); position = ftell(fp); printf(“\n Now, we are on the FIRST byte, FPI=%ld”, position); fseek(fp,0L,SEEK_END); position = ftell(fp); printf(“\n Now, we are on the LAST byte, FPI=%ld”, position); fseek(fp,10L,SEEK_SET); position = ftell(fp); printf(“\n Now, we are on the byte 10 from begining, FPI=%ld”, position); fseek(fp,-10L,SEEK_END); position = ftell(fp); printf(“\n Now, we are on the byte 10 from end, FPI=%ld”, position); fclose(fp); }

4 C.13 3 Example 1 » Problem 1: Write a program to create a binary file called “TEST.TXT”, and fill it with 300 randomly selected small case letters. Hint: It was seen that, to generate a random number between 5 to 60, the formula was: 5 + rand() % ( 60 – 5 +1); Therefore, the formula for random letters between ‘a’ to ‘z’ should be: ‘a’ + rand() % ( ‘z’ - ’a’ +1);

5 C.13 4 Example 1 » Solution: #include void main() { FILE *fp; int i; randomize(); fp = fopen(“TEST.TXT","wb"); for (i=0; i<300; i++) putc('a'+rand()%('z'-'a'+1), fp); fclose(fp); }

6 C.13 5 Example 2 » Problem 2: Write a program to find the length (size in number of bytes) and display of the binary file “TEST.TXT”. » Use a method that is not needing any sequential read or any loop! HINT: Use fseek() to go to the end of file, and then use the ftell() to learn the FPI content.

7 C.13 6 Example 2 » Solution: #include void main() { FILE *fp; long j=0; fp = fopen(“TEST.TXT","rb"); fseek(fp,0L, SEEK_END); j=ftell(fp); printf("\n The number of bytes = %ld", j); getch(); }

8 C.13 7 Example 3 » Problem 3: Write a program to read the binary file “TEST.TXT” to do the followings: a) List the all content (sequential read). b) List only the letters, which are on the odd numbered positions within the file. c) List only the letters, which are on the even numbered positions within the file. HINT: Use fseek() and modify “offset” argument to move two by two on the file.

9 C.13 8 Example 3 » Solution: #include void main() { FILE *fp; int i; char ch; long j=0; fp = fopen(“TEST.TXT","rb"); printf("\n The all :\n"); while (!feof(fp)) { ch=getc(fp); printf("%c",ch); }

10 C.13 9 Example 3 » Solution: (continous) printf("\n\n\n The Odd Positioned characters :\n"); for (i=0; i<150; i++) { j=2*i+1; fseek(fp, j, SEEK_SET); ch=getc(fp); printf("%c",ch); } printf("\n\n\n The Even Positioned characters :\n"); for (i=0; i<150; i++) { j=2*i; fseek(fp, j, SEEK_SET); ch=getc(fp); printf("%c",ch); } fclose(fp); getch(); }

11 C.13 10 Example 4 » Problem 4: Write a program to read the binary file “TEST.TXT” in REVERSE order and write into another binary file “REVERSE.TXT”. HINT: a) Use fseek() with SEEK_END value to find the last letter of the file. b) Use a loop and check the FPI with ftell() to know if it is still greater then zero (Is it reached to the position of the first letter of the file). c) On every turn of the loop, after getc() (reading a letter), use fseek with –2L offset to position the FPI to the previous of the current letter (in order to process file in reverse order).

12 C.13 11 Example 4 » Solution: #include void main() { FILE *fp_in, *fp_out; long j; char ch; fp_in = fopen("DENEME.TXT","rb"); fp_out = fopen("REVERSE.TXT","wb"); fseek(fp_in,-1L, SEEK_END);

13 C.13 12 Example 4 » Solution: (Continous) j=ftell(fp_in); /* Position of the first letter of the file */ while (j>0) /* Is the current position the fist letter’s position ?*/ { ch=getc(fp_in);/* getch() automatically advancing the FPI to next */ fseek(fp_in,-2L, SEEK_CUR); /* Set the FPI to the previous position*/ putc(ch,fp_out); j=ftell(fp_in); /* Set the current position into the variable J*/ printf("\n %ld",j); } ch=getc(fp_in);/* Read the first letter of the file*/ putc(ch,fp_out); fclose(fp_in); fclose(fp_out); getch(); }


Download ppt "Applications with Random File Access CHAPTER 8. C.13 1 Where am I on the Binary File? » While a binary file is processed, it is a need to know current."

Similar presentations


Ads by Google