我编写了一个 rexeg 字符串来将日志解析为一组组,但是当存在日志的可选部分时,它会创建一个空组。我已经?
在正则表达式中标记了可选部分,但它似乎仍然创建了一个空组。
这是我尝试过的两个正则表达式;
([0-9]{2}:[0-9]{2}\.[0-9]{2}) - (DMG|KILL):[ ]+(.*?)\[(.*?)\] (?:damaged|killed) (.*?) \[(.*?)\](?: for (\d{0,9}) dmg)?
([0-9]{2}:[0-9]{2}\.[0-9]{2}) - (DMG|KILL):[ ]+(.*?)\[(.*?)\] (?:damaged|killed) (.*?) \[(.*?)\](?: for (\d{0,9})? dmg)?
我的第二个正则表达式在 结束后有一个问号(\d{0,9})
,因为我认为这可能会创建空组,但似乎并非如此。我正在按照以下内容解析字符串;
00:00.00 - DMG: Player [group] damaged Victim [group] for 130 dmg
00:00.00 - KILL: Player [group] killed Victim [group]
在解析最后一行(no for X damage
)时,最后会创建一个空组。
我为可怕的正则表达式道歉。
已经证明我的正则表达式工作正常,感谢评论部分的@Sniffer。可以在这里看到它按预期工作,但是当实现到我的应用程序中时,它没有。
在我的应用程序中,matcher.group(7)
“KILL”行上的(最后一组)(不包含“dmg”的行返回 null,并且 matcher.groupCount() 返回 7 而不是 6,这意味着它在最后找到一个空组。我的正则表达式如下;
private static final Pattern match = Pattern.compile("([0-9]{2}:[0-9]{2}\\.[0-9]{2}) - (DMG|KILL):[ \t]+(.*?)\\[(.*?)\\] (?:damaged|killed) (.*?) \\[(.*?)\\](?: for (\\d{0,9}) dmg)?");
这是我用来匹配模式的代码;
Matcher matcher = DamageEvent.match.matcher(tLine);
if (matcher.matches())
{
int matches = matcher.groupCount();
if (matches < 6 || matches > 7)
{
System.err.println("Invalid line: " + tLine);
return null;
}
String time = matcher.group(1);
String type = matcher.group(2);
String attackerName = matcher.group(3);
String attackerGroupString = matcher.group(4);
String victimName = matcher.group(5);
String victimGroupString = matcher.group(6);
String damage = "0";
System.out.println(matches);
if (matches == 7) // This results as 'true'
{
damage = matcher.group(7); // Damage is set to null :(
}
}