search

Home  >  Q&A  >  body text

java - How to extract html content using regular expressions

    <p class="info-detail-head-classify-subname"><a id="info_detail_head_classify_type" href="" target="_blank">财富</a></p>
    
    
    想用java 提取财富两个字 请问用正则怎么提取 

    用jsoup会不会简单一点
習慣沉默習慣沉默2775 days ago479

reply all(2)I'll reply

  • 伊谢尔伦

    伊谢尔伦2017-05-17 10:08:13

    You can use jsoup and regex, it is recommended to use jsoup!
    jsoup document:
    https://jsoup.org/cookbook/in...
    http://www.open-open.com/jsoup/

    
        import org.jsoup.Jsoup;
        import org.jsoup.nodes.Document;
        import org.jsoup.nodes.Element;
        
        import java.util.regex.Matcher;
        import java.util.regex.Pattern;
        
        public class Main {
        
            public static void main(String[] args) {
        
                // 方法1: jsoup
                String html = "<p class=\"info-detail-head-classify-subname\"><a id=\"info_detail_head_classify_type\" href=\"\" target=\"_blank\">财富</a></p>";
        
                Document doc = Jsoup.parse(html);
                Element element = doc.getElementById("info_detail_head_classify_type");
                System.out.println(element.text());
        
                // 方法2: regex
                Pattern r = Pattern.compile("<a.*>(.*)</a>");
                Matcher m = r.matcher(html);
                if (m.find()) {
                    System.out.println(m.group(1));
                }
            }
        }
    

    reply
    0
  • 淡淡烟草味

    淡淡烟草味2017-05-17 10:08:13

    <a[^>]*>([^<]*)</a>
    

    Get the content in <a></a>

    reply
    0
  • Cancelreply