您问题中的模式正在消耗state
with中的第一个字母[^#]
,这导致匹配无法继续,因为它试图匹配tate
模式\(state\)
。
您传递了标志REG_EXTENDED
,这意味着您不会逃避捕获括号,而是逃避文字括号。
使用正则表达式,说出您想要匹配的内容:
^[ \\t]*(state)[ \\t]*:.*$
如在
#include <stdio.h>
#include <regex.h>
int main(int argc, char **argv)
{
struct {
const char *input;
int expect;
} tests[] = {
/* should match */
{ "state : q0", 1 },
{ "state: q0", 1 },
{ "state:q0s", 1 },
/* should not match */
{ "#state :q0", 0 },
{ "state q0", 0 },
{ "# state :q0", 0 },
};
int i;
regex_t start_state;
const char *pattern = "^[ \\t]*(state)[ \\t]*:.*$";
if (regcomp(&start_state, pattern, REG_EXTENDED)) {
fprintf(stderr, "%s: bad pattern: '%s'\n", argv[0], pattern);
return 1;
}
for (i = 0; i < sizeof(tests)/sizeof(tests[0]); i++) {
int status = regexec(&start_state, tests[i].input, 0, NULL, 0);
printf("%s: %s (%s)\n", tests[i].input,
status == 0 ? "match" : "no match",
!status == !!tests[i].expect
? "PASS" : "FAIL");
}
regfree(&start_state);
return 0;
}
输出:
状态:q0:匹配(通过)
状态:q0:匹配(通过)
状态:q0s:匹配(通过)
#state :q0: 不匹配(通过)
状态 q0:不匹配 (PASS)
# state :q0: no match (PASS)