美文网首页
java爬虫基础--jsoup

java爬虫基础--jsoup

作者: 永不熄灭的火焰_e306 | 来源:发表于2020-02-28 11:17 被阅读0次

    java爬虫框架---jsoup

    在实际的开发过程中,jsoup仅仅作为对html界面解析的工具

    一、解析URL

    Jsoup可以直接输入url,它会发起请求并获取数据,封装为Document对象

    @Test
    public void testJsoupUrl() throws Exception {
        //    解析url地址
        Document document = Jsoup.parse(new URL("http://www.itcast.cn/"), 1000);
    
        //获取title的内容
        Element title = document.getElementsByTag("title").first();
        System.out.println(title.text());
    }
    

    二、解析字符串

    Jsoup可以直接输入字符串,并封装为Document对象

    @Test
    public void testJsoupString() throws Exception {
        //读取文件获取
        String html = FileUtils.readFileToString(new File("D:\\jsoup.html"), "UTF-8");
    
        //    解析字符串
        Document document = Jsoup.parse(html);
    
        //获取title的内容
        Element title = document.getElementsByTag("title").first();
        System.out.println(title.text());
    
    }
    

    三、解析文件

    Jsoup可以直接解析文件,并封装为Document对象

    @Test
    public void testJsoupHtml() throws Exception {
        //    解析文件
        Document document = Jsoup.parse(new File("D:\\jsoup.html"),"UTF-8");
    
        //获取title的内容
        Element title = document.getElementsByTag("title").first();
        System.out.println(title.text());
    }
    

    四、使用dom方式遍历文档

    4.1 元素获取

    1. 根据id查询元素getElementById
    2. 根据标签获取元素getElementsByTag
    3. 根据class获取元素getElementsByClass
    4. 根据属性获取元素getElementsByAttribute
    //1.    根据id查询元素getElementById
    Element element = document.getElementById("city_bj");
    
    //2.   根据标签获取元素getElementsByTag
    element = document.getElementsByTag("title").first();
    
    //3.   根据class获取元素getElementsByClass
    element = document.getElementsByClass("s_name").last();
    
    //4.   根据属性获取元素getElementsByAttribute
    element = document.getElementsByAttribute("abc").first();
    element = document.getElementsByAttributeValue("class", "city_con").first();
    
    

    4.2 对元素中的数据获取

    元素中获取数据

    1. 从元素中获取id
    2. 从元素中获取className
    3. 从元素中获取属性的值attr
    4. 从元素中获取所有属性attributes
    5. 从元素中获取文本内容text
    //获取元素
    Element element = document.getElementById("test");
    
    //1.   从元素中获取id
    String str = element.id();
    
    //2.   从元素中获取className
    str = element.className();
    
    //3.   从元素中获取属性的值attr
    str = element.attr("id");
    
    //4.   从元素中获取所有属性attributes
    str = element.attributes().toString();
    
    //5.   从元素中获取文本内容text
    str = element.text();
    

    4.3 使用选择器语法

    4.3.1 ****使用选择器语法查找元素**

    jsoup elements对象支持类似于CSS (或jquery)的选择器语法,来实现非常强大和灵活的查找功能。这个select 方法在Document, Element,或Elements对象中都可以使用。且是上下文相关的,因此可实现指定元素的过滤,或者链式选择访问。

    Select方法将返回一个Elements集合,并提供一组方法来抽取和处理结果。

    4.3.2 Selector选择器概述

    tagname: 通过标签查找元素,比如:span

    #id: 通过ID查找元素,比如:# city_bj

    .class: 通过class名称查找元素,比如:.class_a

    [attribute]: 利用属性查找元素,比如:[abc]

    [attr=value]: 利用属性值来查找元素,比如:[class=s_name]

    //tagname: 通过标签查找元素,比如:span
    Elements span = document.select("span");
    for (Element element : span) {
        System.out.println(element.text());
    }
    
    //#id: 通过ID查找元素,比如:#city_bjj
    String str = document.select("#city_bj").text();
    
    //.class: 通过class名称查找元素,比如:.class_a
    str = document.select(".class_a").text();
    
    //[attribute]: 利用属性查找元素,比如:[abc]
    str = document.select("[abc]").text();
    
    //[attr=value]: 利用属性值来查找元素,比如:[class=s_name]
    str = document.select("[class=s_name]").text();
    
    4.3.3 Selector选择器组合使用

    el#id: 元素+ID,比如: h3#city_bj

    el.class: 元素+class,比如: li.class_a

    el[attr]: 元素+属性名,比如: span[abc]

    任意组合: 比如:span[abc].s_name

    ancestor child: 查找某个元素下子元素,比如:.city_con li 查找"city_con"下的所有li

    parent > child: 查找某个父元素下的直接子元素,比如:

    .city_con > ul > li 查找city_con第一级(直接子元素)的ul,再找所有ul下的第一级li

    parent > *: 查找某个父元素下所有直接子元素

    //el#id: 元素+ID,比如: h3#city_bj
    String str = document.select("h3#city_bj").text();
    
    //el.class: 元素+class,比如: li.class_a
    str = document.select("li.class_a").text();
    
    //el[attr]: 元素+属性名,比如: span[abc]
    str = document.select("span[abc]").text();
    
    //任意组合,比如:span[abc].s_name
    str = document.select("span[abc].s_name").text();
    
    //ancestor child: 查找某个元素下子元素,比如:.city_con li 查找"city_con"下的所有li
    str = document.select(".city_con li").text();
    
    //parent > child: 查找某个父元素下的直接子元素,
    //比如:.city_con > ul > li 查找city_con第一级(直接子元素)的ul,再找所有ul下的第一级li
    str = document.select(".city_con > ul > li").text();
    
    //parent > * 查找某个父元素下所有直接子元素.city_con > *
    str = document.select(".city_con > *").text();
    

    相关文章

      网友评论

          本文标题:java爬虫基础--jsoup

          本文链接:https://www.haomeiwen.com/subject/iamkhhtx.html