以前解析有規律的文件的時候要麼用正則表達式,要麼就是傻傻的自己寫程序來解析有規律的文件。今天突然發現c的庫函數中有一個現成的可以解析有規律的文件的函數,就是fscanf()函數。哎 以前自己做了這麼多無用功,在這裏詳細解析一下fscanf函數:
fscanf()函數(有點像正則表達式):
功 能: 從一個流中執行格式化輸入,fscanf遇到空格和換行時結束,注意空格時也結束。
用 法:int fscanf(FILE *stream, char *format,[argument...]);
int fscanf(文件指針,格式字符串,輸入列表);
for example:
FILE*fp;
chara[10];
intb;
doublec;
fscanf(fp,"%s%d%lf",a,&b,&c)
返回值:整型,數值等於[argument...]的個數
其中的format就是相當於正則表達式中的格式,即用什麼樣的格式來分隔文件中的信息。光說不好理解,一下用一個例子來說明具體怎麼用:
首先我有一個data。txt的文件裏面的數據格式如下:
2,50,41,w,20.585828
4,52,51,r,52.012547
.........................
許多條類似的記錄,都是以,來分隔的
.......................
我實現的功能就是把上面文件中的數據的五個字段賦值給相應的五個變量,並且輸出這些變量的值。實現的程序如下:
#include<stdio.h>
#include<stdlib.h>
int main()
{
int fd;
long dev;
long offset;
long length;
char ch;
double ts=0.000000;
if((fd=fopen("/home/haixian/ceshi/data.txt","r"))<0)
{
printf("open the file is error!\n");
exit(0);
}
lseek(fd,0,SEEK_SET);
while(5==fscanf(fd,"%ld,%ld,%ld,%c,%lf\n",&dev,&offset,&length,&ch,&ts))
{在這裏就是第二個參數指定分隔參數的格式,在這裏使用的是,來分隔。這樣就很容易的獲取了記錄的各個字段的值並不需要自己編寫函數來進行解析什麼的。
printf("%ld,%ld,%ld,%c,%lf\n",dev,offset,length,ch,ts);
}
close(fd);
return 0;
}
通過上面的例子能很好的理解fscanf函數的用法。以前自己寫程序解析這種文件,費力還不討好,得出的結果還不準確。哎 只能感嘆我太弱了,以後還得好好學習!!!!