我定义了以下模式来解析我们自己的自定义函数,即<functionName>[<arg1>, <arg2>, ..]
,模式为:([a-zA-Z0-9]+)\\[(([a-zA-Z0-9]+)(,([a-zA-Z0-9])+)*?)*?\\]
现在,当我针对示例函数properCase[ARG1,ARG2]
运行此命令时,将得到以下输出:
Total matches are: 5
Group number 0is: properCase[ARG1, ARG2]
Group number 1is: properCase
Group number 2is: ARG1
Group number 3is: ARG1
Group number 4is: ,ARG2
码:
Matcher m = funcPattern.matcher("properCase[ARG1, ARG2]");
System.out.println("Match found: " + m.matches());
System.out.println("Total matches are: " + m.groupCount());
if (m.matches())
{
for (int index= 0 ; index < m.groupCount(); index++)
{
System.out.println("Group number "+ index + "is: " +m.group(index));
}
}
如何仅提取函数名称(作为组1)和参数列表(作为组2,组3)?我无法从群组中删除
,
。 最佳答案
我无法使用您提供的正则表达式来匹配properCase[ARG1, ARG2]
,但是要更广泛地回答您的问题,您应该使用非捕获组(?:your_regex)
使其不包含在匹配器组中
编辑:
如果您不习惯使用单个正则表达式进行解析,请考虑以下事项:将字符串拆分为函数名称和参数组,然后使用定界符将参数组拆分,
import java.util.regex.*
String regex="([a-zA-Z0-9]+)\\[([ ,.a-zA-Z0-9]+)\\]"
Pattern funcPattern = Pattern.compile(regex);
Matcher m = funcPattern.matcher("properCase[ARG1, ARG2, class.otherArg]");
System.out.println("Match found: " + m.matches());
System.out.println("Total matches are: " + m.groupCount());
if (m.matches())
{
for (int index= 0 ; index <= m.groupCount(); index++)
{
System.out.println("Group number "+ index + "is: " +m.group(index));
}
}
println "Arguments: " + m.group(2).split(",");
产生:
Match found: true
Total matches are: 2
Group number 0is: properCase[ARG1, ARG2, class.otherArg]
Group number 1is: properCase
Group number 2is: ARG1, ARG2, class.otherArg
Arguments: [ARG1, ARG2, class.otherArg]
关于java - 用于函数调用的正则表达式模式,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/9724143/