所以我们有一个名为dictionary1.txt的文件,它包含单词,其发音就在它们旁边。我想要做的是从每一行获取第一个单词并将它们打印到程序从头开始创建的另一个 txt 文件中。我的代码可以做到这一点,但它还在英文单词之间打印随机中文字母,我不知道为什么。
输出文件如下所示:https://imgur.com/a/pZthP
(在dictionary1.txt中,每行的发音与实际单词之间用空格分隔)
我的代码:
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[]) {
char line[100];
int i = 0;
FILE* fp1 = fopen("dictionary1.txt", "r");
FILE* fp2 = fopen("dictionary2.txt", "w");
if (fp1 == NULL || fp2 == NULL){
printf("ERROR");
return -1;
}
while (fgets(line, 100, fp1) != NULL){
while (line[i] != ' '){
fputc(line[i], fp2);
i++;
}
i=0;
fputc('\0', fp2);
}
return 0;
}
我也尝试了 fputc('\n', fp2) ,但无论如何我都无法进入我从头开始创建的文件中的下一行。我也无法摆脱所有随机的中文字母。
编辑:我明白了。我正在处理的 .txt 文件以 Unicode 格式保存,这不适用于我的程序。我把它变成了 ANSI,现在它就像一个魅力。
最佳答案
\n 并不是所有操作系统和所有编辑器上的正确行分隔符。
如果您在记事本上编辑 txt 文件,请尝试 fputs ("\r\n", fp2);
,其中\r 表示回车(光标在该行的第一个字符处返回)和\n 表示换行。
一般来说,Windows 使用“\r\n”作为行分隔符,“\n”字符显示为除结束行之外的其他内容,至少在记事本中是这样。 Linux 和 Mac OS 使用不同的行分隔符。您可能还想尝试fprintf(fp2, "\n");
看一下这个
\n and \r seem to work everywhere. Why is line.separator more portable?
如果你不介意使用 C++,你可以尝试创建一个输出流 os
并写 os << endl
请注意,有些编译器可能会自动将 '\n' 转换为相应的操作系统结束行字符/字符序列,而有些编译器可能不会。
还有一点,把while循环条件改成line[i] != ' ' && line[i] != '\0'
并关闭文件fp2
使用fclose
.
关于C 程序从 .txt 文件获取每行的第一个单词并将该单词打印到另一个 .txt 文件 : Kind of works but also prints random letters,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46920214/