test.txt:
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb
ccccccccccccccccccccccccccccccccccc
The color of the car is blue
法典:
FILE *fp;
char var[30];
int result
if( (fp = fopen( "test.txt", "r")) == NULL) //open for read
printf("ERROR");
result = fscanf( fp, "The color of the car is %s", &var);
执行后:
打开文件(不是 NULL,能够在测试时执行追加(
结果 = 0//零- 在匹配失败的情况下....?
errno = 0;
而VAR是垃圾。
我期待 fscanf(( 匹配"蓝色"。
我应该如何正确地将蓝色放入变量中?谢谢。
改用fgets
怎么样:
char *search = "The color of the..";
char *p;
while (fgets(var, SIZE, stdin)) {
/* Does it have what we want ? */
if ((p = strstr(var, search)))
break;
}
if (p)
p += strlen(str);
Fscanf 不是这样工作的。它不会环顾四周,也不会扫描字符串以查找要匹配的内容。您必须提供与格式说明符完全匹配的字符串。所以你可以做这样的事情
result = fscanf(fp, "aaaaaaaaaaaaanbbbbbbbbbbbnccccccccccnThe color of the car is %s", &var);
实现你想要的。
你有一个错误,当你应该传入一个指向char的指针时,你将指向char数组的指针传递给fscanf
。碰巧数组的地址等于数组第一个元素的地址,所以它偶然起作用。但是,传入了错误的类型。
此外,您想找到为您提供匹配的行,并且您似乎想将"blue"
存储到var
中。为此,您应该测试一行输入是否与您的扫描模式匹配。您可以使用fgets
读取一行,并使用sscanf
扫描该行。
while (fgets(buf, sizeof(buf), fp) != 0) {
result = sscanf(buf, "The color of the car is %s", var);
if (result == 1) break;
}
sscanf
将返回它成功扫描的指令数。在这种情况下,有一个%s
指令。
这样做可以防止扫描错误"干扰"您的输入解析。也就是说,如果fscanf
返回错误,则在您调用 clearerr()
之前,它将无法越过导致错误的输入。
你在这里还有另一个错误,如果 test.txt 不存在,你的代码无论如何都会继续使用 fscanf,使你的检查毫无用处。这几乎肯定会导致程序崩溃。
使用正则表达式
char p[100];
char q[100];
char r[100];
fscanf(fp, "%[^n]n%[^n]n%[^n]nThe color of the car is %s",p,q,r, &var);
根据您的要求对其进行修改。我知道这不是你的实际字符串。