fopen()函數(shù)功能:打開一個文件。
成都創(chuàng)新互聯(lián)公司2013年至今,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站建設(shè)、網(wǎng)站制作網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元貴定做網(wǎng)站,已為上家服務(wù),為貴定各地企業(yè)和個人服務(wù),聯(lián)系電話:18982081108
原型:FILE * fopen(const char * path,const char * mode);
需要#includestdio.h
返回值:文件順利打開后,指向該流的文件指針就會被返回。如果文件打開失敗則返回NULL,并把錯誤代碼存在errno 中。
一般打開文件會進(jìn)行讀取或?qū)懭氩僮鳎绻蜷_文件失敗,也就無法順利進(jìn)行相應(yīng)的讀寫操作,所以一般在調(diào)用fopen()之后要作錯誤判斷及處理。
#include stdio.h
FILE *stream;
void main( void )
{
long l;
float fp;
char s[81];
char c;
stream = fopen( "fscanf.out", "w+" );
if( stream == NULL )
printf( "The file fscanf.out was not opened\n" );
else
{
fprintf( stream, "%s %ld %f%c", "a-string",
65000, 3.14159, 'x' );
/* Set pointer to beginning of file: */
fseek( stream, 0L, SEEK_SET );
/* Read data back from file: */
fscanf( stream, "%s", s );
fscanf( stream, "%ld", l );
fscanf( stream, "%f", fp );
fscanf( stream, "%c", c );
/* Output data read: */
printf( "%s\n", s );
printf( "%ld\n", l );
printf( "%f\n", fp );
printf( "%c\n", c );
fclose( stream );
}
}
看了MSDN上的這個例子應(yīng)該會用fprintf和fscanf了吧
其它的函數(shù)在MSDN上基本上都有例子參考的.
//要另外說下如fprintf(stderr, "Can't open %s\n", file_app);這是向文件或者系統(tǒng)設(shè)備輸出的函數(shù);但他的文件指針為stderr;這是c中的標(biāo)準(zhǔn)錯誤輸出設(shè)備指針,系統(tǒng)自動分配為顯示器故相當(dāng)于printf("Can't open %s\n", file_app);
#include stdio.h
#include stdlib.h
#include string.h
#define BUFSIZE 1024
#define SLEN 81
void append(FILE *source, FILE *dest);
int main(void)
{
FILE *fa, *fs; //定義2個文件類型指針
int files = 0; // 追加文件個數(shù)
char file_app[SLEN];
char file_src[SLEN]; // 2個字符串用來儲存文件名;
puts("Enter name of destination file:");//輸出Enter name of destination file:
gets(file_app);//輸入要追加的文件名
if ((fa = fopen(file_app, "a")) == NULL)//fa指向追加的目的文件,以追加方式打開文件,如果打開失敗退出;
{
fprintf(stderr, "Can't open %s\n", file_app);
exit(2);
}
if (setvbuf(fa, NULL, _IOFBF, BUFSIZE) != 0)//創(chuàng)建緩沖器與流相關(guān),大小為BUFSIZE,作用是提高IO速度;如果打開失敗退出
{
fputs("Can't create output buffer\n", stderr);
exit(3);
}
puts("Enter name of first source file (empty line to quit):");//輸出Enter name of first source file (empty line to quit):
while (gets(file_src) file_src[0] != '\0')//輸入源文件如果是空串結(jié)束循環(huán)
{
if (strcmp(file_src, file_app) == 0)//如果源和追加文件相同
fputs("Can't append file to itself\n",stderr);
else if ((fs = fopen(file_src, "r")) == NULL)//如果打開源文件失敗
fprintf(stderr, "Can't open %s\n", file_src);
else
{
if (setvbuf(fs, NULL, _IOFBF, BUFSIZE) != 0)//創(chuàng)建緩沖器與流相關(guān),大小為BUFSIZE,作用是提高IO速度;如果打開失敗開始下次循環(huán)
{
fputs("Can't create input buffer\n",stderr);
continue;
}
append(fs, fa);//函數(shù)
if (ferror(fs) != 0)//檢查文件操作是否有錯
fprintf(stderr,"Error in reading file %s.\n",
file_src);
if (ferror(fa) != 0)
fprintf(stderr,"Error in writing file %s.\n",
file_app);
fclose(fs);//關(guān)閉源文件
files++;//追加文件數(shù)+1
printf("File %s appended.\n", file_src);
puts("Next file (empty line to quit):");
}
}
printf("Done. %d files appended.\n", files);
fclose(fa);//關(guān)閉追加文件
return 0;
}
void append(FILE *source, FILE *dest)
{
size_t bytes;
static char temp[BUFSIZE];
while ((bytes = fread(temp,sizeof(char),BUFSIZE,source)) 0)//把源文件的內(nèi)容追加到追加文件,塊大小sizeof(char),塊數(shù)為BUFSIZE
fwrite(temp, sizeof (char), bytes, dest);//寫文件塊大小sizeof(char),塊數(shù)為BUFSIZE
}
在ANSI C中,對文件的操作分為兩種方式,即流式文件操作和I/O文件操作,下面就分別介紹之。
一、流式文件操作
這種方式的文件操作有一個重要的結(jié)構(gòu)FILE,F(xiàn)ILE在stdio.h中定義如下:
typedef struct {
int level;
unsigned flags;
char fd;
unsigned char hold;
int bsize;
unsigned char _FAR *buffer;
unsigned char _FAR *curp;
unsigned istemp;
short token;
} FILE;
FILE這個結(jié)構(gòu)包含了文件操作的基本屬性,對文件的操作都要通過這個結(jié)構(gòu)的指針來進(jìn)行,此種文件操作常用的函數(shù)見下表 函數(shù) 功能
fopen() 打開流
fclose() 關(guān)閉流
fputc() 寫一個字符到流中
fgetc() 從流中讀一個字符
fseek() 在流中定位到指定的字符
fputs() 寫字符串到流
fgets() 從流中讀一行或指定個字符
fprintf() 按格式輸出到流
fscanf() 從流中按格式讀取
feof() 到達(dá)文件尾時返回真值
ferror() 發(fā)生錯誤時返回其值
rewind() 復(fù)位文件定位器到文件開始處
remove() 刪除文件
fread() 從流中讀指定個數(shù)的字符
fwrite() 向流中寫指定個數(shù)的字符
tmpfile() 生成一個臨時文件流
tmpnam() 生成一個唯一的文件名
下面就介紹一下這些函數(shù)
1.fopen()
fopen的原型是:FILE *fopen(const char *filename,const char *mode),fopen實(shí)現(xiàn)三個功能
為使用而打開一個流
把一個文件和此流相連接
給此流返回一個FILR指針
參數(shù)filename指向要打開的文件名,mode表示打開狀態(tài)的字符串,其取值如下表
字符串 含義
"r" 以只讀方式打開文件
"w" 以只寫方式打開文件
"a" 以追加方式打開文件
"r+" 以讀/寫方式打開文件,如無文件出錯
"w+" 以讀/寫方式打開文件,如無文件生成新文件
一個文件可以以文本模式或二進(jìn)制模式打開,這兩種的區(qū)別是:在文本模式中回車被當(dāng)成一個字符'n',而二進(jìn)制模式認(rèn)為它是兩個字符0x0D,0x0A;如果在文件中讀到0x1B,文本模式會認(rèn)為這是文件結(jié)束符,也就是二進(jìn)制模型不會對文件進(jìn)行處理,而文本方式會按一定的方式對數(shù)據(jù)作相應(yīng)的轉(zhuǎn)換。
系統(tǒng)默認(rèn)的是以文本模式打開,可以修改全部變量_fmode的值來修改這個設(shè)置,例如_fmode=O_TEXT;就設(shè)置默認(rèn)打開方式為文本模式;而_fmode=O_BINARY;則設(shè)置默認(rèn)打開方式是二進(jìn)制模式。
我們也可以在模式字符串中指定打開的模式,如"rb"表示以二進(jìn)制模式打開只讀文件,"w+t"或"wt+"表示以文本模式打開讀/寫文件。
此函數(shù)返回一個FILE指針,所以申明一個FILE指針后不用初始化,而是用fopen()來返回一個指針并與一個特定的文件相連,如果成敗,返回NULL。
例:
FILE *fp;
if(fp=fopen("123.456","wb"))
puts("打開文件成功");
else
puts("打開文件成敗");
2.fclose()
fclose()的功能就是關(guān)閉用fopen()打開的文件,其原型是:int fclose(FILE *fp);如果成功,返回0,失敗返回EOF。
在程序結(jié)束時一定要記得關(guān)閉打開的文件,不然可能會造成數(shù)據(jù)丟失的情況,我以前就經(jīng)常犯這樣的毛病。
例:fclose(fp);
3.fputc()
向流寫一個字符,原型是int fputc(int c, FILE *stream); 成功返回這個字符,失敗返回EOF。
例:fputc('X',fp);
4.fgetc()
從流中讀一個字符,原型是int fputc(FILE *stream); 成功返回這個字符,失敗返回EOF。
例:char ch1=fgetc(fp);
5. fseek()
此函數(shù)一般用于二進(jìn)制模式打開的文件中,功能是定位到流中指定的位置,原型是int fseek(FILE *stream, long offset, int whence);如果成功返回0,參數(shù)offset是移動的字符數(shù),whence是移動的基準(zhǔn),取值是
符號常量 值 基準(zhǔn)位置
SEEK_SET 0 文件開頭
SEEK_CUR 1 當(dāng)前讀寫的位置
SEEK_END 2 文件尾部
例:fseek(fp,1234L,SEEK_CUR);//把讀寫位置從當(dāng)前位置向后移動1234字節(jié)(L后綴表示長整數(shù))
fseek(fp,0L,2);//把讀寫位置移動到文件尾
6.fputs()
寫一個字符串到流中,原型int fputs(const char *s, FILE *stream);
例:fputs("I Love You",fp);
7.fgets()
從流中讀一行或指定個字符,原型是char *fgets(char *s, int n, FILE *stream); 從流中讀取n-1個字符,除非讀完一行,參數(shù)s是來接收字符串,如果成功則返回s的指針,否則返回NULL。
例:如果一個文件的當(dāng)前位置的文本如下
Love ,I Have
But ........
如果用
fgets(str1,4,file1);
則執(zhí)行后str1="Lov",讀取了4-1=3個字符,而如果用
fgets(str1,23,file1);
則執(zhí)行str="Love ,I Have",讀取了一行(不包括行尾的'n')。
8.fprintf()
按格式輸入到流,其原型是int fprintf(FILE *stream, const char *format[, argument, ...]);其用法和printf()相同,不過不是寫到控制臺,而是寫到流罷了
例:fprintf(fp,"%2d%s",4,"Hahaha");
9.fscanf()
從流中按格式讀取,其原型是int fscanf(FILE *stream, const char *format[, address, ...]);其用法和scanf()相同,不過不是從控制臺讀取,而是從流讀取罷了。
例:fscanf(fp,"%d%d" ,x,y);
10.feof()
檢測是否已到文件尾,是返回真,否則返回0,其原型是int feof(FILE *stream);
例:if(feof(fp))printf("已到文件尾");
11.ferror()
原型是int ferror(FILE *stream);返回流最近的錯誤代碼,可用clearerr()來清除它,clearerr()的原型是void clearerr(FILE *stream);
例:printf("%d",ferror(fp));
12.rewind()
把當(dāng)前的讀寫位置回到文件開始,原型是void rewind(FILE *stream);其實(shí)本函數(shù)相當(dāng)于fseek(fp,0L,SEEK_SET);
例:rewind(fp);
12.remove()
刪除文件,原型是int remove(const char *filename); 參數(shù)就是要刪除的文件名,成功返回0。
例:remove("c:io.sys");
13.fread()
從流中讀指定個數(shù)的字符,原型是size_t fread(void *ptr, size_t size, size_t n, FILE *stream);參數(shù)ptr是保存讀取的數(shù)據(jù),void*的指針可用任何類型的指針來替換,如char*、int *等等來替換;size是每塊的字節(jié)數(shù);n是讀取的塊數(shù),如果成功,返回實(shí)際讀取的塊數(shù)(不是字節(jié)數(shù)),本函數(shù)一般用于二進(jìn)制模式打開的文件中。
例:
char x[4230];
FILE *file1=fopen("c:msdos.sys","r");
fread(x,200,12 ,file1);//共讀取200*12=2400個字節(jié)
14.fwrite()
與fread對應(yīng),向流中寫指定的數(shù)據(jù),原型是size_t fwrite(const void *ptr, size_t size, size_t n, FILE *stream);參數(shù)ptr是要寫入的數(shù)據(jù)指針,void*的指針可用任何類型的指針來替換,如char*、int *等等來替換;size是每塊的字節(jié)數(shù);n是要寫的塊數(shù),如果成功,返回實(shí)際寫入的塊數(shù)(不是字節(jié)數(shù)),本函數(shù)一般用于二進(jìn)制模式打開的文件中。
例:
char x[]="I Love You";
fwire(x, 6,12,fp);//寫入6*12=72字節(jié)
將把"I Love"寫到流fp中12次,共72字節(jié)
15.tmpfile()
其原型是FILE *tmpfile(void); 生成一個臨時文件,以"w+b"的模式打開,并返回這個臨時流的指針,如果失敗返回NULL。在程序結(jié)束時,這個文件會被自動刪除。
例:FILE *fp=tmpfile();
16.tmpnam();
其原型為char *tmpnam(char *s); 生成一個唯一的文件名,其實(shí)tmpfile()就調(diào)用了此函數(shù),參數(shù)s用來保存得到的文件名,并返回這個指針,如果失敗,返回NULL。
例:tmpnam(str1);
二、直接I/O文件操作
這是C提供的另一種文件操作,它是通過直接存/取文件來完成對文件的處理,而上篇所說流式文件操作是通過緩沖區(qū)來進(jìn)行;流式文件操作是圍繞一個FILE 指針來進(jìn)行,而此類文件操作是圍繞一個文件的“句柄”來進(jìn)行,什么是句柄呢?它是一個整數(shù),是系統(tǒng)用來標(biāo)識一個文件(在WINDOWS中,句柄的概念擴(kuò)展到所有設(shè)備資源的標(biāo)識)的唯一的記號。此類文件操作常用的函數(shù)如下表,這些函數(shù)及其所用的一些符號在io.h和fcntl.h中定義,在使用時要加入相應(yīng)的頭文件。
函數(shù) 說明
open() 打開一個文件并返回它的句柄
close() 關(guān)閉一個句柄
lseek() 定位到文件的指定位置
read() 塊讀文件
write() 塊寫文件
eof() 測試文件是否結(jié)束
filelength() 取得文件長度
rename() 重命名文件
chsize() 改變文件長度
下面就對這些函數(shù)一一說明:
1.open()
打開一個文件并返回它的句柄,如果失敗,將返回一個小于0的值,原型是int open(const char *path, int access [, unsigned mode]); 參數(shù)path是要打開的文件名,access是打開的模式,mode是可選項(xiàng)。表示文件的屬性,主要用于UNIX系統(tǒng)中,在DOS/WINDOWS這個參數(shù)沒有意義。其中文件的打開模式如下表。
符號 含義 符號 含義 符號 含義
O_RDONLY 只讀方式 O_WRONLY 只寫方式 O_RDWR 讀/寫方式
O_NDELAY 用于UNIX系統(tǒng) O_APPEND 追加方式 O_CREAT 如果文件不存在就創(chuàng)建
O_TRUNC 把文件長度截為0 O_EXCL 和O_CREAT連用,如果文件存在返回錯誤 O_BINARY 二進(jìn)制方式
O_TEXT 文本方式
對于多個要求,可以用"|"運(yùn)算符來連接,如O_APPEND|O_TEXT表示以文本模式和追加方式打開文件。
例:int handle=open("c:msdos.sys",O_BINARY|O_CREAT|O_WRITE)
2.close()
關(guān)閉一個句柄,原型是int close(int handle);如果成功返回0
例:close(handle)
3.lseek()
定位到指定的位置,原型是:long lseek(int handle, long offset, int fromwhere);參數(shù)offset是移動的量,fromwhere是移動的基準(zhǔn)位置,取值和前面講的fseek()一樣,SEEK_SET:文件首部;SEEK_CUR:文件當(dāng)前位置;SEEK_END:文件尾。此函數(shù)返回執(zhí)行后文件新的存取位置。
例:
lseek(handle,-1234L,SEEK_CUR);//把存取位置從當(dāng)前位置向前移動1234個字節(jié)。
x=lseek(hnd1,0L,SEEK_END);//把存取位置移動到文件尾,x=文件尾的位置即文件長度
4.read()
從文件讀取一塊,原型是int read(int handle, void *buf, unsigned len);參數(shù)buf保存讀出的數(shù)據(jù),len是讀取的字節(jié)。函數(shù)返回實(shí)際讀出的字節(jié)。
例:char x[200];read(hnd1,x,200);
5.write()
寫一塊數(shù)據(jù)到文件中,原型是int write(int handle, void *buf, unsigned len);參數(shù)的含義同read(),返回實(shí)際寫入的字節(jié)。
例:char x[]="I Love You";write(handle,x,strlen(x));
7.eof()
類似feof(),測試文件是否結(jié)束,是返回1,否則返回0;原型是:int eof(int handle);
例:while(!eof(handle1)){……};
8.filelength()
返回文件長度,原型是long filelength(int handle);相當(dāng)于lseek(handle,0L,SEEK_END)
例:long x=filelength(handle);
9.rename()
重命名文件,原型是int rename(const char *oldname, const char *newname); 參數(shù)oldname是舊文件名,newname是新文件名。成功返回0
例:rename("c:config.sys","c:config.w40");
10.chsize();
改變文件長度,原型是int chsize(int handle, long size);參數(shù)size表示文件新的長度,成功返回0,否則返回-1,如果指定的長度小于文件長度,則文件被截短;如果指定的長度大于文件長度,則在文件后面補(bǔ)''。
例:chsize(handle,0x12345);
C語言對文件進(jìn)行讀取之前需要先打開文件,然后再進(jìn)行讀寫,讀寫完之后關(guān)閉文件。
可以使用兩組函數(shù)實(shí)現(xiàn):
一、C語言庫函數(shù)
打開文件:fopen
讀寫(一般對應(yīng)成對使用):
fgetc---fputc fgets---fputs fread---fwrite
關(guān)閉文件:fclose
二、Linux系統(tǒng)函數(shù)
打開文件:open
讀寫(一般對應(yīng)成對使用):read---write
關(guān)閉文件:close