C File Programming
C File Programming
There are a large number of functions to handle file I/O (Input Output) in C. In
this tutorial, you will learn to handle standard I/O in C using fprintf(), fscanf(),
fread(), fwrite(), fseek.and more.
Types of Files
When dealing with files, there are two types of files you should know about:
1. Text files
2. Binary files
1. Text files
Text files are the normal .txt files that you can easily create using Notepad or any
simple text editors.
When you open those files, you'll see all the contents within the file as plain text. You
can easily edit or delete the contents.
They take minimum effort to maintain, are easily readable, and provide least security
and takes bigger storage space.
2. Binary files
Binary files are mostly the .bin files in your computer.
Instead of storing data in plain text, they store it in the binary form (0's and 1's).
They can hold higher amount of data, are not readable easily and provides a better
security than text files.
File Operations
In C, you can perform four major operations on the file, either text or binary:
FILE *fptr;
ptr = fopen("fileopen","mode")
For Example:
fopen("E:\\cprogram\\newprogram.txt","w");
fopen("E:\\cprogram\\oldprogram.bin","rb");
• Let's suppose the file newprogram.txt doesn't exist in the location E:\cprogram. The
first function creates a new file named newprogram.txt and opens it for writing as per
the mode 'w'.
The writing mode allows you to create and edit (overwrite) the contents of the file.
• Now let's suppose the second binary file oldprogram.bin exists in the
location E:\cprogram. The second function opens the existing file for reading in binary
mode 'rb'.
The reading mode only allows you to read the file, you cannot write into the file.
File
Mode Meaning of Mode During Inexistence of file
Open for both reading and If the file does not exist, fopen() returns
r+ writing. NULL.
Open for both reading and If the file does not exist, fopen() returns
rb+ writing in binary mode. NULL.
Closing a File
The file (both text and binary) should be closed after reading/writing.
After you compile and run this program, you can see a text file program.txt created in
C drive of your computer. When you open the file, you can see the integer you
entered.
fwrite(address_data,size_data,numbers_data,pointer_to_file);
The first parameter takes the address of num and the second parameter takes the
size of the structure threeNum.
Since, we're only inserting one instance of num, the third parameter is 1. And, the last
parameter *fptr points to the file we're storing the data.
fread(address_data,size_data,numbers_data,pointer_to_file);
This will waste a lot of memory and operation time. An easier way to get to the
required data can be achieved using fseek().
As the name suggests, fseek() seeks the cursor to the given record in the file.
Syntax of fseek()
fseek(FILE * stream, long int offset, int whence)
The first parameter stream is the pointer to the file. The second parameter is the
position of the record to be found, and the third parameter specifies the location
where the offset starts.
Whence Meaning
SEEK_CUR Starts the offset from the current location of the cursor in the file.
Example 5: fseek()
1. #include <stdio.h>
2. #include <stdlib.h>
3.
4. struct threeNum
5. {
6. int n1, n2, n3;
7. };
8.
9. int main()
10. {
11. int n;
12. struct threeNum num;
13. FILE *fptr;
14.
15. if ((fptr = fopen("C:\\program.bin","rb")) == NULL){
16. printf("Error! opening file");
17.
18. // Program exits if the file pointer returns NULL.
19. exit(1);
20. }
21.
22. // Moves the cursor to the end of the file
23. fseek(fptr, -sizeof(struct threeNum), SEEK_END);
24.
25. for(n = 1; n < 5; ++n)
26. {
27. fread(&num, sizeof(struct threeNum), 1, fptr);
28. printf("n1: %d\tn2: %d\tn3: %d\n", num.n1, num.n2, num.n3);
29. fseek(fptr, -2*sizeof(struct threeNum), SEEK_CUR);
30. }
31. fclose(fptr);
32.
33. return 0;
34. }
This program will start reading the records from the file program.bin in the reverse
order (last to first) and prints it.