尝试从.txt文件中读取时遇到问题 文件示例:“12345 qwe> rty 12345 q = wert qe / ry”试图读取超过5万个相似的行,将它们与另一个(也从doc。读取)数组进行比较,但程序每次都会刹车...... 代码suposte比较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();
}
提前谢谢
答案 0 :(得分: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];
坦率地说,那些令人心旷神怡;对于手头的目的,他们也完全错了。宏通常也以大写形式编写(所以MAX
而不是max
)。您可能正在寻找:
char ime[MAX][200], grad[MAX][200], adresa[MAX][200];
这些是每个MAX
条目的三个数组,每个条目长度为200个字符。这至少是“明智的”,因为它为你提供了分配的空间来阅读;它可能会浪费很多空间,但至少它不应该撞到你身上,这是不明智的。
您的代码应检查fscanf()
调用是否成功。第一个fscanf()
调用的参数需要修复以识别ime[i]
等是数组,并且不需要在它们前面使用&
。检查点打印语句需要以换行符结尾;否则,它们不会及时出现。我也不喜欢输出行尾的尾随空格和制表符。
总而言之,这些变化会产生:
#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,但不清楚它们应该如何排序。因此,代码未经测试,尤其是因为我的Unix机器上没有C:
驱动器。但是,这是一个不同的问题。 (这也是懒惰:我可以很好地在我当前的目录中创建一个文件C:\Users\Fujitsu\001.txt
...)