您可以使用正则表达式组:
Pattern pattern = Pattern.compile("for user (\\w+)");
Matcher matcher = pattern.matcher(s);
if (matcher.find()) {
System.out.println(matcher.group(1));
}一对括号(和)形成一个可以由匹配器使用group方法获得的组(因为它是第一个括号,它是组1)。
\w表示“单词字符”(字母,数字和_),+表示“一个或多个发生次数”。所以\w+基本上意味着“一个字”(假设您的用户名只有这些字符)。 PS:请注意我必须转义\,因此生成的表达式为\\w+。
此代码的输出是:
username
如果要匹配所有值(websiteName,userAgentNameWithSpaces等),可以执行以下操作:
Pattern pattern = Pattern.compile("Rendering content from (.*) using user agent (.*) ; for user (.*) ; at time (.*)");
Matcher matcher = pattern.matcher(s);
if (matcher.find()) {
System.out.println(matcher.group(1));
System.out.println(matcher.group(2));
System.out.println(matcher.group(3));
System.out.println(matcher.group(4));
}输出将是:
websiteNAme
userAgentNameWithSpaces
username
someTime请注意,如果userAgentNameWithSpaces包含空格,则\w+将不起作用(因为\w与空格不匹配),因此在这种情况下.*将起作用。
但您也可以使用[\w ]+ - 括号[]表示“我内部的任何字符”,因此[\w ]表示“单词字符或空格”(注意w和]之间有空格。所以代码就是(测试)用户名和空格):
String s = "Rendering content from websiteNAme using user agent userAgent Name WithSpaces ; for user username ; at time someTime";
Pattern pattern = Pattern.compile("Rendering content from (.*) using user agent ([\\w ]+) ; for user (.*) ; at time (.*)");
Matcher matcher = pattern.matcher(s);
if (matcher.find()) {
System.out.println(matcher.group(1));
System.out.println(matcher.group(2));
System.out.println(matcher.group(3));
System.out.println(matcher.group(4));
}输出将是:
websiteNAme
userAgent Name WithSpaces
username
someTime
注意:您可以在调用matcher.group(n)之前测试组是否匹配。方法matcher.groupCount()返回匹配的组数(因为如果您调用matcher.group(n)且组n不可用,您将获得IndexOutOfBoundsException)