[英]C - Nested loop using strtok
我正在尝试使用strtok将文本文件拆分为可以传递给拼写检查功能的字符串,该文本文件包含诸如'\\ n','?!等字符。 等等...我需要打印所有未通过拼写检查的单词以及它们所在的行号。 我一直在努力跟踪生产线。 到目前为止,我已经尝试过了,但是它只返回文本文件第一行的结果:
char str[409377];
fread(str, noOfChars, 1, file);
fclose(file);
int lines=1;
char *token;
char *line;
char splitLine[] = "\n";
char delimiters[] = " ,.?!(){}*&^%$£_-+=";
line = strtok(str, splitLine);
while(line!=NULL){
token = strtok(line, delimiters);
while(token != NULL){
//print is just to test if I can loop through all the words
printf("%s", token);
//spellCheck function & logic here
token = strtok(NULL, delimiters);
}
line = strtok(NULL, splitLine);
lines++
}
是否可以使用嵌套的while循环和strtok? 有更好的方法来跟踪行号吗?
您可以使用strtok,但是使用起来并不容易。 这是一个愚蠢的函数,它真正要做的就是用nul替换定界符,并返回一个指针,该指针指向已定界的序列的开头。 因此具有破坏性。 它不能处理特殊情况,例如英语单词被允许一个撇号(我们是一个单词,我们不是),您必须确保列出所有分隔符。
最好自己编写mystrok,这样您才能了解它的工作原理。 然后将其用作您自己的单词提取器的基础。
造成该错误的原因是,您砍掉了第一行,然后这就是在随后的调用中strok看到的全部内容。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.