我正在尝试用单词“CENSORED”替换传入的单词,但我无法弄清楚在哪里可以解释替换单词和审查单词之间的区别。这是输入和输出的示例。
./a.out Ophelia draw or <poem.txt
Said Hamlet to CENSORED,
I'll CENSOREDsketch of thee,
What kind of pencil shall I use?
2B CENSORED2B?
但正确的输出应该是:
Said Hamlet to CENSORED,
I'll CENSORED a sketch of thee,
What kind of pencil shall I use?
2B CENSORED not 2B?
完整代码:
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char **argv){
char fileRead[4096];
char replace[] = "CENSORED";
int arg=0;
size_t word_len = strlen(argv[arg]);
while (fgets(fileRead, sizeof(fileRead), stdin) != 0)
{
char *start = fileRead;
char *word_at;
for (arg = 1; arg < argc; arg += 1) {
if ((word_at = strstr(start, argv[arg])) != 0) {
printf("%.*s%s", (int)(word_at - start), start, replace);
start = word_at + word_len -1;
}
}
printf("%s", start);
}
printf("\n");
return (0);
}
我非常感谢任何提示!谢谢:)
最佳答案
创建一个大小为 4096(假设行长度不超过 4096)的临时输出 char
数组,用于存储完整的处理行。如果您从文件中逐字阅读会更好。
将读取的单词与每个可替换单词(Ophelia、draw 或 or)进行比较,如果不需要替换,则将该单词附加到带有空格的输出字符数组中。如果必须替换单词,则将单词 CENSORED
附加到输出字符数组。
如果到达新行 printf
整个输出 char
数组,重复使用输出数组并重复该过程,直到到达 EOF
关于c - 在替换从文本文件中读取的单词的程序中,如何解释不同的单词长度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36393523/