在实际应用中往往会发现这样一些日志文件,它们以一行表示一个记录项,记录项中的每个字段间以空格来分隔。比如,如下日记文件
name1 sex1 age1 height1 weight1
name2 sex2 age2 height2 weight2
对于该类文件的解析可参考如下代码模块:
/*
从Line中读取第N个空格的位置
成功返回第N个空格位置,失败返回NULL
static char * Get_N_Null(char *Line, int N)
{
if((Line == NULL) || (N < 0))
{
printf("Function %s :input para err\n", __FUNCTION__);
return NULL;
}
char *Tmp = Line;
int count = 0;
while(*Tmp)
{
if(count == N)
{
return Tmp;
}
if(*Tmp == ' ')
{
count++;
}
Tmp++;
}
/*最后一个字段没有空格,返回\0 前面一个字符位置*/
if((*Tmp) == '\0')
{
return --Tmp;
}
return NULL;
}
/*
从Line中读取第Num个字段,读取的字段的内容保存到field中,
成功返回0,失败-1
*/
static s_32 get_field(char *Line, int Num, char *field)
{
char *start, *end;
if((Num < 1) || (Line == NULL) || (field == NULL))
{
printf("Function %s :input para err\n", __FUNCTION__);
return -1;
}
if((start = Get_N_Null(Line, Num-1)) == NULL)
{
printf("Get_N_Null(Line, %d) err\n", Num-1);
return -1;
}
if((end = Get_N_Null(Line, Num)) == NULL)
{
printf("Get_N_Null(Line, %d) err\n", Num);
return -1;
}
if((Num - 1) == 0)
{
memcpy(field, start, end - start);
}
else
{
memcpy(field, start, end - start -1);
}
return 0;
}
if((fp = fopen("xxx","r")) == NULL)
{
printf("fopen("xxx","r") err\n");
return -1;
}
while(!feof(fp))
{
memset(Line, '\0', sizeof(Line));
fgets(Line,Line_Max,fp);
memset(field, '\0', sizeof(field));
if(get_field(Line, Num, field))
{
printf("Fuction %s Line %d: get_field(Line, 1, field) err\n", __FUNCTION__, __LINE__);
goto err;
}
else
{
/*符合条件的字段,进行处理*/
}
}
fclose(fp);
这里的代码仅供参考,如有发现不足之处,欢迎指正

919

被折叠的 条评论
为什么被折叠?



