程序應該查看每行file1
,然後查看file2
中是否存在完全相同的行。如果是,則將該行復制到名爲output的新文件。C文件處理:文本不附加在文件末尾
說,以下是文件(這可能是一句話,但爲了簡單起見,我已經把號碼)的內容 -
file1 file2
1 2
2 4
3 15
4 6
5 11
6 8
7
8
9
然後output
文件應該是這樣 -
(Expected) output
2
4
6
8
內殼我可以看到printf按預期打印output
,但fprintf顛倒了順序,我不明白爲什麼?這會打印輸出文件的輸出是 -
output
8
6
4
2
下面的代碼 -
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
FILE *file1, *file2, *output;
int c;
/*Creating buffers where data will be stored for comparison*/
char buffer1[999], buffer2[999];
/*Settig the buffer characters array to 0*/
memset(buffer1, 0, sizeof(buffer1));
memset(buffer2, 0, sizeof(buffer2));
/*Open output file in "w" so that it clears the file*/
output = fopen("output", "w");
/*Open file1 and then save the line inside buffer1 (within while loop)*/
file1 = fopen("file1", "r");
/*Read each character in file until End Of Line*/
while((c = getc(file1)) != EOF)
{
int i = 0;
/*Save each new line of file1 in buffer1 for comparison*/
while(c != '\n')
{
buffer1[i++] = c;
c = getc(file1);
}
/*Open file2 and then save it's line in buffer2 (withing while loop)*/
file2 = fopen("file2", "r");
int ch;
while((ch = getc(file2)) != EOF)
{
i = 0;
while(ch != '\n')
{
buffer2[i++] = ch;
ch = getc(file2);
}
/*Compare lines of file1 against each line of file2*/
if(strcmp(buffer1,buffer2) == 0)
{
/*Save similar lines in a file named output*/
output = fopen("output", "a");
fprintf(output,"%s\n", buffer2);
printf("%s\n", buffer2);
break;
}
/*Reset the buffer*/
memset(buffer2, 0, sizeof(buffer2));
}
memset(buffer1, 0, sizeof(buffer1));
}
/*Close the output file if there were any comparison made i.e. if file was opened*/
if(output != NULL)
{
fclose(output);
}
/*Close other files*/
fclose(file1);
fclose(file2);
return 0;
}
PS:我是初學者,仍然不確定我是否正確編寫代碼,請親切:) 謝謝。 – 2012-07-28 05:52:34
不是「W」使用「W +」 – qrtt1 2012-07-28 05:55:46