<< Chapter < Page Chapter >> Page >

Example

FILE *f1, *f2, *f3, *f4;

To open text file c:\abc.txt for ready only:

f1 = fopen("c:\\abc.txt", "r");

To open text file c:\list.dat for write only:

f2 = fopen("c:\\list.dat", "w");

To open text file c:\abc.txt for read-write:

f3 = fopen("c:\\abc.txt", "r+");

To open binary file c:\liststudent.dat for write only:

f4 = fopen("c:\\liststudent.dat", "wb");

The file pointer will be used with all other functions that operate on the file and it must never be altered or the object it points to.

File checking

if (file_pointer_name == NULL) {printf("Error opening file.");<Action for error>} else{<Action for success>}

Before using an input/output file it is worth checking that the file has been correctly opened first. A call to fopen() may result in an error due to a number of reasons including:

  • A file opened for reading does not exist;
  • A file opened for reading is read protected;
  • A file is being opened for writing in a folder or directory where you do not have write access.

If the operation is successful, fopen () returns an address which can be used as a stream. If a file is not successfully opened, the value NULL is returned. An error opening a file can occur if the file was to be opened for reading and did not exist, or a file opened for writing could not be created due to lack of disk space. It is important to always check that the file has opened correctly before proceeding in the program.

FILE *fp; if ((fp = fopen("myfile", "r")) ==NULL){printf("Error opening file\n"); exit(1);}
Got questions? Get instant answers now!

Once a file has been opened, depending upon its mode, you may read and/or write bytes to or from it.

Access to text files

Write data to text files

When writing data to text files, C provides three functions: fprintf() , fputs() , fputc() .

The fprintf() function prototype is as follows:

int fprintf(FILE *fp, char *format, ...);

This function writes to the file specified by file pointer fp a sequence of data formatted as the format argument specifies. After the format parameter, the function expects at least as many additional arguments as specified in format. Depending on the format string, the function may expect a sequence of additional arguments, each containing one value to be inserted instead of each %-tag specified in the format parameter, if any. There should be the same number of these arguments as the number of %-tags that expect a value.

Return value: On success, the total number of characters written is returned. On failure, a negative number is returned.

#include<stdio.h>int main () {FILE * fp; int n;char name [50];fp = fopen ("myfile.txt","w"); for (n=0 ; n<3 ; n++) {puts ("Please, enter a name: "); gets (name);fprintf (fp, "Name %d [%-10.10s]\n",n,name);} fclose (fp);return 0; }
Got questions? Get instant answers now!

This example prompts 3 times the user for a name and then writes them to myfile.txt each one in a line with a fixed length (a total of 19 characters + newline). Two format tags are used: %d : signed decimal integer, %-10.10s : left aligned (-), minimum of ten characters (10), maximum of ten characters (.10), String (s).

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now




Source:  OpenStax, Introduction to computer science. OpenStax CNX. Jul 29, 2009 Download for free at http://cnx.org/content/col10776/1.1
Google Play and the Google Play logo are trademarks of Google Inc.

Notification Switch

Would you like to follow the 'Introduction to computer science' conversation and receive update notifications?

Ask