我正在开发一个项目,我必须在运行时动态填充的文件中捕获ALIVE / SEARCH / BYEBYE的uuid事件的统计信息(它可以是3个,每个组合2个,或者只有一个)。 / p>
我可以打印所有3种组合,但不能组合1或2,例如
如果我的input.txt是这样的:
uuid:22314754-a597-490b-8a93-02cfae01036b ALIVE 16
uuid:22314754-a597-490b-8a93-02cfae01036b BYEBYE 8
uuid:22314754-a597-490b-8a93-02cfae01036b SEARCH 8
uuid:50e65653-7525-485d-83bf-d293558c4264 ALIVE 32
uuid:50e65653-7525-485d-83bf-d293558c4264 BYEBYE 8
uuid:50e65653-7525-485d-83bf-d293558c4264 SEARCH 132
uuid:55076f6e-6b79-4d65-6497-180373763bc1 ALIVE 113
uuid:55076f6e-6b79-4d65-6497-180373763bc1 BYEBYE 112
uuid:55076f6e-6b79-4d65-6497-180373763bc1 SEARCH 111
uuid:T0100203354 ALIVE 1
uuid:T0100203354 BYEBYE 2
uuid:T0100203354 SEARCH 3
我的代码:
#include<stdio.h>
#include<string.h>
struct uid
{
char uid_val[100];
char state[100];
int temp_count;
int alive_count;
int search_count;
int bye_count;
} UID[100];
int main()
{
char str[100];
int i = 0;
int line = 0;
char temp_val[100] = "waseem";
FILE *fp1 = fopen("input.txt","r");
FILE *fp2=fopen("output.txt","w");
printf("init value is %s \n",temp_val);
while(!feof(fp1))
{
fscanf(fp1,"%s %s %d",UID[i].uid_val,UID[i].state,&UID[i].temp_count);
int ret = 0;
ret=strcmp(UID[i].uid_val,temp_val);
if (ret!=0)
{
printf("new UID_val is %s\n",UID[i].uid_val);
}
else
{
}
temp_val[0] = '\0';
strcpy(temp_val,UID[i].uid_val);
if(strcmp(UID[i].state,"ALIVE")==0)
{
UID[i].alive_count = UID[i].temp_count;
}
else if(strcmp(UID[i].state,"BYEBYE")==0)
{
UID[i].search_count = UID[i].temp_count;
}
else
{
UID[i].bye_count = UID[i].temp_count;
}
line++;
if(line%3 == 0)
{
i++;
}
}
int n = 0;
//fp2=fopen("output.txt","w");
if (fp2==NULL)
{
printf("cant output to file\n");
}
else
{
fprintf(fp2,"Device ID\t\t\t\t\tALIVE\tBYEBYE\tSEARCH\n");
for(n = 0;n < i;n++)
{
fprintf(fp2,"%s\t%d\t%d\t%d\n",UID[n].uid_val,UID[n].alive_count,UID[n].search_count,UID[n].bye_count);
}
}
fclose(fp1);
fclose (fp2);
return 0;
}
}
提供以下输出:(output.txt)
Device ID ALIVE BYEBYE SEARCH
uuid:22314754-a597-490b-8a93-02cfae01036b 16 8 8
uuid:50e65653-7525-485d-83bf-d293558c4264 32 8 132
uuid:55076f6e-6b79-4d65-6497-180373763bc1 113 112 111
uuid:T0100203354 1 2 3
我想概括代码,使得uuid出现不必全部为3(ALIVE / SEARCH / BYEBYE),出现可以是任何组合,代码应该起作用。例如,当input.txt包含以下内容时,我的代码会给出错误的结果:
uuid:22314754-a597-490b-8a93-02cfae01036b BYEBYE 8
uuid:22314754-a597-490b-8a93-02cfae01036b SEARCH 8
uuid:50e65653-7525-485d-83bf-d293558c4264 ALIVE 32
uuid:50e65653-7525-485d-83bf-d293558c4264 BYEBYE 8
uuid:55076f6e-6b79-4d65-6497-180373763bc1 ALIVE 113
uuid:55076f6e-6b79-4d65-6497-180373763bc1 BYEBYE 112
uuid:55076f6e-6b79-4d65-6497-180373763bc1 SEARCH 111
uuid:T0100203354 BYEBYE 2
我正在使用ubuntu作为gcc / g +编译器。
答案 0 :(得分:0)
当您从文件中读取一行并进行处理时,为什么不使用UUID使用strtok对行进行tokenlze?您将为每个处理的行获得多个UUID。
稍后,您需要相应地对这些标记化行进行排序,以便在一个位置获得UUID的所有出现。现在按顺序打印所有令牌的状态。而已。 !!
答案 1 :(得分:0)
我建议你这样做。有一个不同的结构来存储输出,这将降低循环的复杂性。使用之前收到的uid检查您的uid,并相应地分配输出结构。你最好检查我重写的代码。它适用于输出
#include<stdio.h>
#include<string.h>
struct uid
{
char uid_val[100];
char state[100];
int temp_count;
} UID[100];
struct uid1
{
char uid_val[100];
int alive_count;
int search_count;
int bye_count;
} UID_NEW[100];
int main()
{
char str[100];
int i = 0;
int j=0;
FILE *fp1 = fopen("input.txt","r");
FILE *fp2=fopen("output.txt","w");
while(!feof(fp1))
{
fscanf(fp1,"%s %s %d",UID[i].uid_val,UID[i].state,&UID[i].temp_count);
if(i>0)
{
if(strcmp(UID_NEW[j].uid_val,UID[i].uid_val)!=0)
{
j++;
}
}
strcpy(UID_NEW[j].uid_val,UID[i].uid_val);
if(strcmp(UID[i].state,"ALIVE")==0)
{
UID_NEW[j].alive_count = UID[i].temp_count;
}
else if(strcmp(UID[i].state,"BYEBYE")==0)
{
UID_NEW[j].search_count = UID[i].temp_count;
}
else
{
UID_NEW[j].bye_count = UID[i].temp_count;
}
i++;
}
int n = 0;
if (fp2==NULL)
{
printf("cant output to file\n");
}
else
{
fprintf(fp2,"Device ID\t\t\t\t\tALIVE\tBYEBYE\tSEARCH\n");
for(n = 0;n <= j;n++)
{
fprintf(fp2,"%50s\t%3d\t%3d\t%3d\n",UID_NEW[n].uid_val,UID_NEW[n].alive_count,UID_NEW[n].search_count,UID_NEW[n].bye_count);
}
}
fclose(fp1);
fclose (fp2);
return 0;
}
答案 2 :(得分:0)
我很遗憾地说这个,但这是一个简单的任务,你应该能够修复代码。请参阅下面的URL,它解释了如何读取字符串的最后一个单词。
C++ find return the last word in the string variable text. string getFirstWord(text)提供此网址的原因是1)如果您清楚地看到,您的输入文件就像“UUID:asdfsdfsdf名称......”这样的行。第一个空格后面的单词就是您想要的。因此,您需要从文件中读取的行中提取第二个单词2)现在您需要对已解析的标记的内容进行排序。这是另一个简单的任务。使用适当的容器。 3)执行排序并显示结果。现在尝试使用您的结果更新我们。