- Jsoup 教程
- jsoup - 主頁
- jsoup - 概述
- jsoup - 環境設定
- 示例 - 輸入
- jsoup - 解析字串
- jsoup - 解析 body
- jsoup - 載入 URL
- jsoup - 載入檔案
- 示例 - 提取資料
- jsoup - 使用 DOM 方法
- jsoup - 使用選擇器語法
- jsoup - 提取屬性
- jsoup - 提取文字
- jsoup - 提取 HTML
- jsoup - 使用 URL
- 示例 - 修改資料
- jsoup - 設定屬性
- jsoup - 設定 HTML
- jsoup - 設定文字內容
- 示例 - 清除 HTML
- jsoup - 清理 HTML
- jsoup 實用資源
- jsoup - 快速指南
- jsoup - 實用資源
- jsoup - 討論
jsoup - 使用選擇器語法
將 HTML 字串解析為 Document 物件後,以下示例演示選擇器方法的用法。jsoup 支援類似於 CSS 選擇器的選擇器。
語法
Document document = Jsoup.parse(html);
Element sampleDiv = document.getElementById("sampleDiv");
Elements links = sampleDiv.getElementsByTag("a");
其中
document − document 物件表示 HTML DOM。
Jsoup − 用於解析給定 HTML 字串的主類。
html − HTML 字串。
sampleDiv − Element 物件表示 ID 為“sampleDiv”的 html 節點元素。
links − Elements 物件表示用標籤“a”標識的多個節點元素。
描述
document.select(expression) 方法解析給定的 CSS 選擇器表示式來選擇一個 html dom 元素。
示例
使用你選擇的編輯器在 C:/> jsoup 中建立以下 java 程式。
JsoupTester.java
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
public class JsoupTester {
public static void main(String[] args) {
String html = "<html><head><title>Sample Title</title></head>"
+ "<body>"
+ "<p>Sample Content</p>"
+ "<div id='sampleDiv'><a href='www.google.com'>Google</a>"
+ "<h3><a>Sample</a><h3>"
+"</div>"
+ "<div id='imageDiv' class='header'><img name='google' src='google.png' />"
+ "<img name='yahoo' src='yahoo.jpg' />"
+"</div>"
+"</body></html>";
Document document = Jsoup.parse(html);
//a with href
Elements links = document.select("a[href]");
for (Element link : links) {
System.out.println("Href: " + link.attr("href"));
System.out.println("Text: " + link.text());
}
// img with src ending .png
Elements pngs = document.select("img[src$=.png]");
for (Element png : pngs) {
System.out.println("Name: " + png.attr("name"));
}
// div with class=header
Element headerDiv = document.select("div.header").first();
System.out.println("Id: " + headerDiv.id());
// direct a after h3
Elements sampleLinks = document.select("h3 > a");
for (Element link : sampleLinks) {
System.out.println("Text: " + link.text());
}
}
}
驗證結果
使用 javac 編譯器編譯類,如下所示
C:\jsoup>javac JsoupTester.java
現在執行 JsoupTester 以檢視結果。
C:\jsoup>java JsoupTester
檢視結果。
Href: www.google.com Text: Google Name: google Id: imageDiv Text: Sample
廣告