C/C++文件操作,数据处理

jopen 10年前

        在ANSI C中,对文件的操作分为两种方式,即流式文件操作I/O 文件操作,这里我们只介绍流式文件操作。(1)FILE

    进行文件操作时,必须在程序一开始就先定义文件指针:FILE 指针类型变量。FILE 在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;</pre>(2)fopen
FILE fopen(const char filename,const char mode);</pre>"r"(只读)       为输入打开一个文本文件。若指定的文件不存在,则会出错。
"w"(只写)       为输出打开一个文本文件。若文件不存在,系统将用指定名建立一个新文件;若文件已经存在,则将从起始位置重新写,原有内容被更新
"rb"(只读)      为输入打开一个二进制文件。功能与"r"相同。
"wb"(只写)      为输出打开一个二进制文件。功能与"w"相同。
"a"(追加)       为追加数据打开一个文本文件。若文件不存在,系统将用指定名建立一个新文件;若文件已经存在,则新数据写在原有内容之后
"ab"(追加)      为追加数据打开一个二进制文件。其余功能与"a"相同。
"r+"(读写)</span>     为读/写打开一个已存在文本文件。既可读,也可写,读写总是从文件的起始位置开始更换读写操作时不必关闭文件。
"rb+"(读写)     为读/写打开一个已存在的二进制文件。功能与"r+"相同。可由位置函数设置读写的起始位置。
"w+"(读写)      为读/写建立一个新的文本文件。若文件已存在,原有内容将被更新。
"wb+"(读写)     为读/写建立一个新的二进制文件。功能与"w+"相同;可由位置函数设置读写起始位置。
"a+"(读写)      为读/写打开一个文本文件。功能与"a"相同,只是在文件尾部添加新数据后,可以从头开始读。
"ab+"(读写)     为读/写打开一个二进制文件。功能与"a+"相同,只是在文件尾部添加新数据之后,可由位置  函数设置开始读的起始位置。
         此函数返回一个FILE 指针,所以申明一个FILE 指针后不用初始化,而是用fopen()来返回一个指针并与一个特定的文件相连,如果成败,返回NULL。 

FILE *fp;  if( fp=fopen("A.TXT","r") == NULL)  {      printf("can't find this file!/n");      exit(0);  }
(3)fgetc
int fgetc(FILE *stream);
       从文件指针stream指向的文件中读取一个字符,读取一个字节后,光标位置后移一个字节。这个函数的返回值,是返回所读取的一个字节。如果读到文件末尾或者读取出错时返回EOF。用法如下:
char ch1=fgetc(fp);

(4)fgets
char *fgets(char *buf, int bufsize, FILE *stream);
buf: 字符型指针,指向用来存储所得数据的地址。
bufsize: 整型数据,指明buf指向的字符数组的大小。
stream: 文件结构体指针,将要读取的文件流。
        从文件结构体指针stream中读取数据,每次读取一行。读取的数据保存在buf指向的字符数组中,每次最多读取bufsize-1个字符(第bufsize个字符赋'\0'),如果文件中的该行,不足bufsize个字符,则读完该行就结束。函数成功将返回buf,失败或读到文件结尾返回NULL。因此我们不能直接通过fgets的返回值来判断函数是否是出错而终止的,应该借助feof函数或者ferror函数来判断。
例:如果一个文件的当前位置的文本如下:
Love, I Have
Since you can do it.
        如果用fgets(str1,6,file1);去读取,则执行后str1 = "Love," ,读取了6-1=5个字符,这个时候再执行fgets(str1,20,file1)则执行后str1 = " I Have\n"。而如果fgets(str1,23,file1);
则执行str1="Love ,I Have",读取了一行(包括行尾的'\n',并自动加上字符串结束符'\0'),当前文件位置移至下一行,虽然23大于当前行上字符总和,可是不会继续到下一行。而下一次调用fgets()继续读取的时候是从下一行开始读。

(5)fscanf

int fscanf(FILE *stream, char *format,[argument...]);
       FILE stream:文件指针;char format:格式字符串(查看其他资料,包括输入格式、忽略元素、包含元素等);[argument...]:输入列表。
       从一个流、文件(stream)中读入数据,执行格式化输入,然后将结果按照格式保存在列表中(可以理解为:将TXT文件中的内容,有针对性地提取出来,并保存在特定的列表、数组中),fscanf遇到空格和换行时结束,注意空格时也结束。这与fgets有区别,fgets遇到空格不结束。
FILE *fp = 0;  char tmp[255] = {0};  fp = fopen(argv[1],"r+");  while(EOF != fscanf(fp,"%*[^','],\"%*[^','],%[^','],%*s",tmp))  {       sscanf(tmp,"\"%s\"",tmp1);       printf("%d\n",atoi(tmp1));  }
(6)fprintf
 int fprintf(FILE *stream,char *format,[argument]);
       printf是标准输出流的输出函数,用来向屏幕这样的标准输出设备输出,而fprintf则是向文件输出,将输出的内容输出到硬盘上的文件或是相当于文件的设备上。根据指定的format(格式)发送信息(参数)到由stream(流)指定的文件. fprintf()只能和printf()一样工作. fprintf()的返回值是输出的字符数,发生错误时返回一个负值.

char s[] = "this is a string";  char c = '\n';  stream = fopen( "fprintf.out", "w" );  fprintf( stream, "%s%c", s, c );  fprintf( stream, "%d\n", i );  fprintf( stream, "%f\n", fp );

(7)fwrite

size_t fwrite(const void* buffer, size_t size, size_t count, FILE* stream);
       buffer:是一个指针,对fwrite来说,是要获取数据的地址;size:要写入内容的单字节数;count:要进行写入size字节的数据项的个数;stream:目标文件指针;返回实际写入的数据项个数count。向文件写入一个数据块,这个函数以二进制形式对文件进行操作,不局限于文本文件。
    FILE *stream;      struct mystruct s;      if ((stream = fopen("TEST.$$$", "wb")) == NULL) /* open file TEST.$$$ */      {          fprintf(stderr, "Cannot open output file.\n");          return 1;      }      s.i = 0;      s.cha = 'A';      fwrite(&s, sizeof(s), 1, stream); /* 写的struct文件*/
(8)sscanf
int sscanf(const char *buffer,const char *format,[argument ]...);
       fscanf是从文件中读,sscanf是从字符串中读,scanf是从键盘输入中读。sscanf会从buffer(一般为字符型数组、字符串)里读进数据,依照format的格式将数据写入到argument(一般为字符型数组)里。
sscanf("123456abcdedfBCDEF","%[1-9A-Z]",buf);  sscanf("iios/12DDWDFF@122", "%*[^/]/%[^@]", buf);  printf("%s\n", buf);
(9)getline
ssize_t getline(char **lineptr, size_t *n, FILE *stream);
       lineptr:指向存放该行字符的指针,如果是NULL,则有系统帮助malloc,请在使用完成后free释放。n:如果是由系统malloc的指针,请填0。stream:文件描述符。getline()函数会生成一个包含一串从输入流读入的字符的字符串,直到一下情况发生会导致生成的此字符串结束。1)到文件结束,2)遇到函数的定界符,3)输入达到最大限度。

FILE *fp;  char *line = NULL;  size_t len = 0;  ssize_t read;    if(!(fp=fopen("1.txt","r")))  {        printf("\nerror on open 1.txt file!\n");        exit(1);  }  while ((read = getline(&line, &len, fp)) != -1);

来自:http://blog.csdn.net/look595271601/article/details/16047369