需要帮助在C中以不同格式打印文件?

时间:2013-09-13 05:11:37

标签: c file parsing printing

我正在开发一个项目,我必须在运行时动态填充的文件中捕获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 +编译器。

3 个答案:

答案 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)执行排序并显示结果。现在尝试使用您的结果更新我们。