-1

我在尝试从 .txt 文件中读取时遇到问题,文件示例:“12345 qwe>rty 12345 q=wert qe/ry”尝试读取超过 50 000 条类似的行,将它们与另一个进行比较(也从 doc. ) 数组,但程序每次都会刹车......代码 supote 比较 2 个数组,如果它们匹配,则在新文档中打印它们。希望我解释清楚...`

#include <stdio.h>

#define max 57000

main()
{
  int i, j, n;
  char (*ime[200])[max], (*grad[200])[max], (*adresa[200])[max];
  int rb[max], rbk[max], posta[max], check[max];
  FILE *svi = fopen("C:\\Users\\Fujitsu\\Desktop\\001.txt", "r");
  FILE *kupci = fopen("C:\\Users\\Fujitsu\\Desktop\\002txt", "r");
  FILE *izlaz = fopen("C:\\Users\\Fujitsu\\Desktop\\003.txt", "w");
  //  reading from 001.txt//
  // 
  printf("1");    //some kind of check point
  for (i = 2; i < 56300; i++)
  {
    fscanf(svi, "%d%s%d%s%s", &rb[i], &ime[i], &posta[i], &grad[i], &adresa[i]);
    check[i] = 0;
    fscanf(kupci, "%d", &n);
    rbk[n] = 0;
  }
  //matching 001 i 002//
  printf("2");
  for (i = 2; i < 56300; i++)
  {
    if (check[i] == rbk[i])
    {
      check[i] = 1;
    }
    //stampanje u novu datoteku 003 //
    if (check[i] == 0)
    {
      fprintf(izlaz, "%szt%d\t%s\t%s\t\n", ime[i], posta[i], grad[i],
          adresa[i]);
      ;
    }
  }
  fclose(svi);
  fclose(kupci);
  fclose(izlaz);
  printf("done");
  getch();
}

先感谢您

4

1 回答 1

2

这里有几个问题。问题的直接原因可能是您没有检查是否成功打开文件,并且其中一个名称缺少它.

FILE *svi   = fopen("C:\\Users\\Fujitsu\\Desktop\\001.txt", "r");
FILE *kupci = fopen("C:\\Users\\Fujitsu\\Desktop\\002txt", "r");  // <<-- .txt???
FILE *izlaz = fopen("C:\\Users\\Fujitsu\\Desktop\\003.txt", "w");

目前尚不清楚该rbk数组是否已正确初始化。

很明显,您不希望指向数组的指针:

char (*ime[200])[max], (*grad[200])[max], (*adresa[200])[max];

坦率地说,这些都令人兴奋。对于手头的目的,他们也是完全错误的。宏通常也是全部大写的(soMAX而不是max)。您可能正在寻找:

char ime[MAX][200], grad[MAX][200], adresa[MAX][200];

这是三个条目数组MAX,每个条目有 200 个字符长。这至少是“明智的”,因为它为您分配了阅读空间;这是不明智的,因为它可能会浪费很多空间,但至少它不应该在你身上崩溃。

您的代码应检查fscanf()调用是否成功。第一次fscanf()调用的参数需要修复以识别ime[i]etc 是数组并且不需要&它们前面的。检查点打印语句需要以换行符结尾;否则,它们不会及时出现。我也不喜欢输出行末尾的尾随空格和制表符。

总而言之,这些变化产生:

#include <stdio.h>
#include <string.h>

#define MAX 57000

int main(void)
{
    int i, n;
    char ime[MAX][200], grad[MAX][200], adresa[MAX][200];
    int rb[MAX], rbk[MAX], posta[MAX], check[MAX];
    FILE *svi   = fopen("C:\\Users\\Fujitsu\\Desktop\\001.txt", "r");
    FILE *kupci = fopen("C:\\Users\\Fujitsu\\Desktop\\002.txt", "r");
    FILE *izlaz = fopen("C:\\Users\\Fujitsu\\Desktop\\003.txt", "w");

    if (svi == 0 || kupci == 0 || izlaz == 0)
    {
        fprintf(stderr, "Failed to open at least one file\n");
        return 1;
    }

    memset(rbk, '\xFF', sizeof(rbk));  // Not zero - that's too friendly.

    printf("1\n");    //some kind of check point
    for (i = 2; i < MAX; i++)
    {
        if (fscanf(svi, "%d%s%d%s%s", &rb[i], ime[i], &posta[i], grad[i], adresa[i]) != 5)
            break;
        check[i] = 0;
        if (fscanf(kupci, "%d", &n) != 1)
            break;
        rbk[n] = 0;
    }
    int max = i;

    printf("2\n");
    for (i = 2; i < max; i++)
    {
        if (check[i] == rbk[i])
            check[i] = 1;
        if (check[i] == 0)
            fprintf(izlaz, "%s\t%d\t%s\t%s\n", ime[i], posta[i], grad[i], adresa[i]);
    }
    fclose(svi);
    fclose(kupci);
    fclose(izlaz);
    printf("done\n");
    return 0;
}

它编译时没有警告。我无法弄清楚这些文件是如何组织的;似乎它002.txt不只是按顺序包含数字 1..N,但尚不清楚它们应该如何排序。C:因此,代码未经测试,尤其是因为我的Unix 机器上没有驱动器。然而,这是一个不同的问题。(这也是一种懒惰:我完全可以C:\Users\Fujitsu\001.txt在当前目录中创建一个文件......)

于 2013-05-26T06:06:46.553 回答