0

我正在尝试浏览文件,直到找到两行,其中第一行的前 4 位与下一个的前 4 位不同。为此,我一直在使用 fseek 浏览它,直到找到我想要的序列。这是一个按十年排列的人口列表,每十年有不止一条线,但它们都是按顺序排列的,从最旧的年份到最新的年份。我在 main 中使用 ftell 来获取第一个偏移量,以便我可以在文件中间开始读取。

这里的问题是,即使偏移量为正并且它应该向前,它也会继续向后移动。

应该使它前进的行是这样的:

encontrar_inicio(f, ano, offset/2);

这就是它所显示的:

1980 é maior que 1950 ano maior, anda para a frente
1980 é maior que 1910 ano maior, anda para a frente
1980 é maior que 1900 ano maior, anda para a frente
1980 é maior que 1880 ano maior, anda para a frente
1980 é maior que 1860 ano maior, anda para a frente

它说 1980 比 [year] 大,往前走。但事实并非如此。在给出这些行的 printf 之后是我在上面发布的行。

这是整个功能:

void encontrar_inicio (FILE *f, int ano, long int offset)
{
    int i, meio, ano2;
    char aux[100], aux2[100], aux3[100], lixo[100];

    //printf("%lu\n", offset);
    fseek( f, offset, SEEK_SET);

    fgets(aux, 100, f);

    fgets(aux2, 5, f);

    ano2 = atoi(aux2);

    if(ano==ano2)
    {
        printf("%d é igual a %d anos iguais, anda para trás\n", ano, ano2);
        encontrar_inicio(f, ano, -offset/2);//go back in the file
    }
    if(ano != ano2)
    {   if(ano < ano2)
        {
            printf("%d é menor q %d ano menor, anda para trás\n", ano, ano2);
            encontrar_inicio(f, ano, -offset/2);//go back in the file
        }
        if(ano > ano2)
        {
            printf("aqui\n");
            fgets(lixo, 100, f);//next line
            fgets(aux3, 5, f);
            int ano3 = atoi(aux3);


            if(ano==ano3)
            {
                printf("%d é igual a %d Encontrou o ano, começa a ler\n", ano, ano3);
                return;
                //começa a ler
            }
            if(ano!=ano3)
            {
                printf("%d é maior que %d ano maior, anda para a frente\n", ano, ano3);
                encontrar_inicio(f, ano, offset/2); //go forward in the file

            }

        }
    }
}

我一直在改变一些事情,但我无法做到这一点。任何帮助,将不胜感激。

如果这个问题有任何问题,我也会道歉,因为这是我的第一个问题。

它读取的文件是这样的(中间有几十年):

year,age,marst,sex,people
1850,0,0,1,1483789
1850,0,0,2,1450376
1850,5,0,1,1411067
2000,90,4,2,29292
2000,90,5,1,147615
2000,90,5,2,774069
2000,90,6,1,15627
2000,90,6,2,59113

编辑 - 结束这样做,它就像一个魅力。

void encontrar_inicio (FILE *f, int ano, long offsetmin, long offsetmax)
{
    int ano2;
    char aux[100], aux2[200], aux3[100], *aux4, lixo[100], lixo2[100];
    long meio;

    meio = (offsetmin+offsetmax)/2;

    int anoinicio = inicio_ficheiro_ano(f);

    if(ano==anoinicio)
    {
        printf("%d igual a %d, começar a ler", ano, anoinicio);
        //inserir dados em;
        return;
    }

    fseek( f, meio, SEEK_SET);

    fgets(aux, 100, f);

    fgets(aux2, 200, f);

    aux4 = strtok(aux2, ",");

    ano2 = atoi(aux4);

    if(ano==ano2)
    {
        printf("%d é igual a %d anos iguais, anda para trás\n", ano, ano2);
        //return;
        encontrar_inicio(f, ano, offsetmin, meio);//go back in the file
    }
    if(ano != ano2)
    {   if(ano < ano2)
        {
            printf("%d é menor q %d ano menor, anda para trás\n", ano, ano2);
            //return;
            encontrar_inicio(f, ano, offsetmin, meio);//go back in the file
        }
        if(ano > ano2)
        {
            fgets(lixo, 100, f);//next line
            fgets(aux3, 5, f);
            int ano3 = atoi(aux3);

            if(ano==ano3)
            {
                printf("%d é igual a %d Encontrou o ano, começa a ler\n", ano, ano3);
                fseek(f, -strlen(aux2), SEEK_CUR);
                return;
                //começa a ler
            }
            if(ano!=ano3)
            {
                printf("%d é maior que %d ano maior, anda para a frente\n", ano, ano3);
                encontrar_inicio(f, ano, meio, offsetmax); //go forward in the file

            }

        }
    }
}
4

2 回答 2

0

您可能喜欢使用SEEK_CUR相对于当前位置进行搜索,但SEEK_SET绝对是哪个位置。

于 2013-05-22T06:13:21.220 回答
0

您可能想尝试更改第一个encontrar_inicio

encontrar_inicio(f, ano, offset/2);

(您的版本使用负偏移量)

第二个是:

encontrar_inicio(f, ano, offset + ((maxOffset - offset)/2));

(你的版本是往回走,而不是往前走。偏移量大于偏移量/2)

于 2013-05-22T00:41:37.183 回答