欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java爬蟲實現(xiàn)Jsoup利用dom方法遍歷Document對象

 更新時間:2022年05月17日 16:49:51   作者:Cyril_KI  
本文主要介紹了Java爬蟲實現(xiàn)Jsoup利用dom方法遍歷Document對象,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

先給出網(wǎng)頁地址:

https://wall.alphacoders.com/featured.php?lang=Chinese

主要步驟:

利用Jsoup的connect方法獲取Document對象

String html = "https://wall.alphacoders.com/featured.php?lang=Chinese";
Document doc = Jsoup.connect(html).get();

內(nèi)容過長,就不再顯示。

我們以這部分為例:

<ul class="nav nav-pills"> 
    <li><a  rel="external nofollow"  rel="external nofollow"  >About Us</a></li> 
    <li><a  rel="external nofollow"  rel="external nofollow"  >FAQ</a></li> 
    <li><a  rel="external nofollow"  rel="external nofollow"  >Privacy Policy</a></li> 
    <li><a  rel="external nofollow"  rel="external nofollow"  >Terms Of Service</a></li> 
    <li><a  rel="external nofollow"  rel="external nofollow"  >Acceptable Use</a></li> 
    <li><a  rel="external nofollow"  rel="external nofollow"  >Etiquette</a></li> 
    <li><a  rel="external nofollow"  rel="external nofollow"  >Advertise With Us</a></li> 
    <li><a id="change_consent">Change Consent</a></li> 
</ul> 

我們先找到所有的ul:

Elements elements = doc.getElementsByTag("ul");

輸出如下:

<ul class="nav navbar-nav center"> 
 <li> <a title="Submit Wallpapers"  rel="external nofollow" ><i class="el el-circle-arrow-up"></i> 提交</a> </li> 
 <li> <a  rel="external nofollow" ><i class="el el-gift"></i> 精美獎品</a> </li> 
</ul>
<ul class="nav navbar-nav navbar-right center"> 
 <li> <a href="language.php?lang=Chinese" rel="external nofollow" > <img src="https://static.alphacoders.com/wa/Chinese-flag.png" alt="Chinese-flag">   中文    </a> </li> 
 <li> <a   rel="external nofollow" ><i class="el el-user"></i> 登錄</a> </li> 
 <li> <a  rel="external nofollow" ><i class="el el-edit"></i> 注冊</a> </li> 
</ul>
<ul class="pagination"> 
 <li class="active"><a id="prev_page" href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >&lt; 上一頁</a></li> 
 <li class="active"><a>1</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >2</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >3</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >4</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >5</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >6</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >7</a></li> 
 <li><a  rel="external nofollow" >8</a></li> 
 <li><a  rel="external nofollow" >9</a></li> 
 <li><a  rel="external nofollow" >10</a></li> 
 <li><a>...</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >319</a></li> 
 <li><a id="next_page"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >下一頁 &gt;</a></li> 
</ul>
<ul class="pagination"> 
 <li class="active"><a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >&lt; 上一頁</a></li> 
 <li class="active"><a>1</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >2</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >3</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >4</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >5</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >6</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >7</a></li> 
 <li><a>...</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >319</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >下一頁 &gt;</a></li> 
</ul>
<ul class="pagination"> 
 <li class="active"><a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >&lt;&lt; </a></li> 
 <li class="active"><a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >&lt; 上一頁</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >下一頁 &gt;</a></li> 
 <li><a title="末頁 (319)"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" > &gt;&gt;</a></li> 
</ul>
<ul class="pagination"> 
 <li class="active"><a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >1</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >2</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >3</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >4</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >5</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >6</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >7</a></li> 
</ul>
<ul class="nav nav-pills"> 
 <li><a  rel="external nofollow"  rel="external nofollow"  >About Us</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  >FAQ</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  >Privacy Policy</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  >Terms Of Service</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  >Acceptable Use</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  >Etiquette</a></li> 
 <li><a  rel="external nofollow"  rel="external nofollow"  >Advertise With Us</a></li> 
 <li><a id="change_consent">Change Consent</a></li> 
</ul>

可以發(fā)現(xiàn)class為"nav nav-pills"的只有一個,我們找到它:

Elements elements = doc.getElementsByTag("ul");
        //System.out.println(elements);
Element tempElement = null;
for(Element element : elements) {
    if (element.className().equals("nav nav-pills")) {
        tempElement = element;
        //System.out.println(element.className());
        break;
    }
}

循環(huán)遍歷這個ul,輸出其中每一個li里每一個a的href和rel屬性:

Elements li = tempElement.getElementsByTag("li");
for(Element element : li) {
    Elements element2 = element.getElementsByTag("a");
    for(Element element3 : element2) {
        String hrefString = element3.attr("href");
        String relString = element3.attr("rel");
        if(hrefString != "" && relString != "") {
            System.out.println("href=" + hrefString + " rel="external nofollow"  rel="external nofollow"  " + "rel=" + relString);
        }
    }
}

最終結(jié)果:

href=https://alphacoders.com/site/about-us rel=nofollow
href=https://alphacoders.com/site/faq rel=nofollow
href=https://alphacoders.com/site/privacy rel=nofollow
href=https://alphacoders.com/site/tos rel=nofollow
href=https://alphacoders.com/site/acceptable_use rel=nofollow
href=https://alphacoders.com/site/etiquette rel=nofollow
href=https://alphacoders.com/site/advertising rel=nofollow

完整代碼:

import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
import java.io.IOException;
import org.jsoup.Jsoup;


/**?
?* @ClassName: Jsoup_Test
?* @description:?
?* @author: KI
?* @Date: 2020年8月17日 下午8:15:14
?*/

public class Jsoup_Test {

?? ?public static void main(String[] args) throws IOException {
?? ??? ?// TODO 自動生成的方法存根
?? ??? ?
?? ??? ?String html = "https://wall.alphacoders.com/featured.php?lang=Chinese";
?? ??? ?Document doc = Jsoup.connect(html).get();
?? ??? ?
?? ??? ?System.out.println(doc);
?? ??? ?Elements elements = doc.getElementsByTag("ul");
?? ??? ?//System.out.println(elements);
?? ??? ?Element tempElement = null;
?? ??? ?for(Element element : elements) {
?? ??? ??? ?if (element.className().equals("nav nav-pills")) {
?? ??? ??? ??? ?tempElement = element;
?? ??? ??? ??? ?//System.out.println(element.className());
?? ??? ??? ??? ?break;
?? ??? ??? ?}
?? ??? ?}
?? ??? ?System.out.println(tempElement);
?? ??? ?Elements li = tempElement.getElementsByTag("li");
?? ??? ?for(Element element : li) {
?? ??? ??? ?Elements element2 = element.getElementsByTag("a");
?? ??? ??? ?for(Element element3 : element2) {
?? ??? ??? ??? ?String hrefString = element3.attr("href");
?? ??? ??? ??? ?String relString = element3.attr("rel");
?? ??? ??? ??? ?if(hrefString != "" && relString != "") {
?? ??? ??? ??? ??? ?System.out.println("href=" + hrefString + " rel="external nofollow"  rel="external nofollow"  " + "rel=" + relString);
?? ??? ??? ??? ?}
?? ??? ??? ?}
?? ??? ?}?? ??? ?

?? ?}

}

到此這篇關(guān)于Java爬蟲實現(xiàn)Jsoup利用dom方法遍歷Document對象的文章就介紹到這了,更多相關(guān)Java Jsoup遍歷Document對象內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 一篇文章從無到有詳解Spring中的AOP

    一篇文章從無到有詳解Spring中的AOP

    。Spring AOP 是基于 AOP 編程模式的一個框架,它的使用有效減少了系統(tǒng)間的重復(fù)代碼,達(dá)到了模塊間的松耦合目的,這篇文章主要給大家介紹了關(guān)于Spring中AOP的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • maven依賴包沖突SLF4J:?Class?path?contains?multiple?SLF4J?bindings處理方法

    maven依賴包沖突SLF4J:?Class?path?contains?multiple?SLF4J?bi

    這篇文章主要給大家介紹了關(guān)于maven依賴包沖突SLF4J:?Class?path?contains?multiple?SLF4J?bindings的處理方法,這個問題通常是因為項目中存在多個SLF4J的實現(xiàn)綁定(bindings)導(dǎo)致的沖突,需要的朋友可以參考下
    2024-02-02
  • Spring Boot實現(xiàn)對文件進(jìn)行壓縮下載功能

    Spring Boot實現(xiàn)對文件進(jìn)行壓縮下載功能

    在Web應(yīng)用中,文件下載功能是一個常見的需求,特別是當(dāng)你需要提供用戶下載各種類型的文件時,本文將演示如何使用Spring Boot框架來實現(xiàn)一個簡單而強(qiáng)大的文件下載功能,需要的朋友跟隨小編一起學(xué)習(xí)吧
    2023-09-09
  • Reactor定制一個生產(chǎn)的WebClient實現(xiàn)示例

    Reactor定制一個生產(chǎn)的WebClient實現(xiàn)示例

    這篇文章主要為大家介紹了Reactor定制一個生產(chǎn)的WebClient實現(xiàn)示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • spring security 5.x實現(xiàn)兼容多種密碼的加密方式

    spring security 5.x實現(xiàn)兼容多種密碼的加密方式

    spring security針對該功能有兩種實現(xiàn)方式,一種是簡單的使用加密來保證基于 cookie 的 token 的安全,另一種是通過數(shù)據(jù)庫或其它持久化存儲機(jī)制來保存生成的 token。這篇文章主要給大家介紹了關(guān)于spring security 5.x實現(xiàn)兼容多種密碼的加密方式,需要的朋友可以參考下。
    2018-01-01
  • Spring Security整合KeyCloak保護(hù)Rest API實現(xiàn)詳解

    Spring Security整合KeyCloak保護(hù)Rest API實現(xiàn)詳解

    這篇文章主要為大家介紹了Spring Security整合KeyCloak保護(hù)Rest API實現(xiàn)實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • SpringBoot中獲取微信用戶信息的方法

    SpringBoot中獲取微信用戶信息的方法

    這篇文章主要介紹了SpringBoot中獲取微信用戶信息的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • java操作Redis緩存設(shè)置過期時間的方法

    java操作Redis緩存設(shè)置過期時間的方法

    這篇文章主要介紹了java操作Redis緩存設(shè)置過期時間的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Java線程池的優(yōu)點及池化技術(shù)的應(yīng)用

    Java線程池的優(yōu)點及池化技術(shù)的應(yīng)用

    這篇文章主要介紹了Java線程池的優(yōu)點及池化技術(shù)的應(yīng)用,Java種提高程序的執(zhí)行效率有兩種實現(xiàn)方法,一個是使用線程、另一個是使用線程池,下文我們就來具體介紹該詳細(xì)內(nèi)容吧,需要的小伙伴可以參考一下
    2022-05-05
  • Java實現(xiàn)Kruskal算法的示例代碼

    Java實現(xiàn)Kruskal算法的示例代碼

    Kruskal算法是一種用來尋找最小生成樹的算法,由Joseph Kruskal在1956年發(fā)表。用來解決同樣問題的還有Prim算法和Boruvka算法等。本文將介紹用Java語言實現(xiàn)Kruskal算法的示例代碼,需要的可以參考一下
    2022-07-07

最新評論