使用Java Pattern在带有属性的HTML标记之间提取单词

时间:2014-03-20 16:26:58

标签: java html regex

我正在使用java Pattern&匹配器提取两个标签之间的单词。

我的代码就像:

final Pattern pattern = Pattern.compile("<([A-Za-z][A-Za-z0-9]*)\\b[^>]*>(.*?)</\\1>");
    List<String> topicArray = new ArrayList<String>();
    final Matcher matcher = pattern.matcher("<City count='1' relevance='0.304' normalized='Shanghai,China'>Shanghai</City>");
    while (matcher.find()) {
        topicArray.add(matcher.group(1));
    }

系统只给我城市作为输出而不是上海。怎么了?

由于

1 个答案:

答案 0 :(得分:0)

您可以尝试下一个:

private static final Pattern REGEX_PATTERN = 
        Pattern.compile("<[^>]*>([^<>]*)<[^>]*>");

public static void main(String[] args) {
    String input = "<City count='1' relevance='0.304' normalized='Shanghai,China'>Shanghai</City>";

    System.out.println(
        REGEX_PATTERN.matcher(input).replaceAll("$1")
    );  // prints "Shanghai"
}