8

我不确定正则表达式是这里最好的解决方案,但它们似乎足够合乎逻辑;我只是不确定如何实际实现这一点。

基本上,我希望我的用户能够输入方法名称并在每个字符输入后对其进行有效性解析。我已经将有效的函数格式定义为正则表达式,并且很容易测试两者是否匹配。麻烦的是,我希望能够进行部分匹配,以便让用户知道,“到目前为止,这是有效的”。

例如,

+(NSString *)thisIsAValid:(ObjectiveC *)method;

是一种有效的方法。它可以通过一个简单的正则表达式字符串来匹配,例如

[\+-]\(w+\s*\*?\)\w+....etc...

. 但我希望能够拥有相同的正则表达式字符串“匹配”

+(NSStr

(我意识到这是使用正则表达式的一种倒退方式)。我仍然不希望正则表达式匹配

Q)(NStr

有没有办法用标准的正则表达式函数来实现这样的东西,还是我必须做一些更激烈的事情?

非常感谢!你们是无价之宝。


经过进一步思考,我想我可以让我的问题更清楚(也更简洁):通常,人们使用正则表达式来查找文本中的模式。即,“猫”或“婴儿床”在本段中出现了多少次。我希望做相反的事情,在正则表达式中寻找一个字符串。也就是说,这个字符串有多少从头开始匹配这个正则表达式。最终,我想返回字符串停止与相关正则表达式匹配的索引。

4

2 回答 2

1

RegexKit 接缝使用 PCRE,因此您可以尝试直接使用 PCRE,因为它支持部分匹配。

#include <stdio.h>
#include <pcre.h>

void test_match(pcre *re, char *subject);

void test_match(pcre *re, char *subject) {
  int rc = pcre_exec(re, NULL, subject, (int)strlen(subject),
                     0, PCRE_PARTIAL, NULL, 0);
  printf("%s: %s\n", subject,
         rc == 0 || rc == PCRE_ERROR_PARTIAL ?
         "match or partial" : "no match");
}

int main (int argc, const char * argv[]) {
  pcre *re;
  const char *errstr;
  int erroffset;

  re = pcre_compile("^ABC$", 0, &errstr, &erroffset, NULL);
  test_match(re, "A");
  test_match(re, "AB");
  test_match(re, "ABC");
  test_match(re, "ABD");

  return 0;
}

将打印:

A: match or partial
AB: match or partial
ABC: match or partial
ABD: no match
于 2012-03-04T13:50:49.873 回答
0

我只想编写一个脚本来获取正则表达式并将其拆分,以便正则表达式 ABCD 成为新的正则表达式:^(ABCD|ABC|AB|A)$

括号会很棘手,因此请尽可能避免使用它们。否则,您可能必须通过添加正确数量的右括号来解决此问题。此外,您必须通过正则表达式运算符对 ABCD 字符串进行标记,这样您就不会拆分 \*+ 之类的内容

于 2012-01-18T12:54:19.473 回答