原文地址:http://www.mkyong.com/java/jsoup-html-parser-hello-world-examples/
,a HTML parser,its “jquery-like” and “regex” selector syntax is very easy to use and flexible enough to get whatever you want. Below are three examples to show you how to use Jsoup to get links,images,page title and “div” element content from a HTML page.
Download jsoupThe jsoup is available in Maven central repository. For non-Maven user,just download it from.
1. Grabs All Hyperlinks
This example shows you how to use jsoup to get page’s title and grabs all links from “google.com”.
<span class="token keyword">import org<span class="token punctuation">.jsoup<span class="token punctuation">.nodes<span class="token punctuation">.Document<span class="token punctuation">;<span class="token keyword">import org<span class="token punctuation">.jsoup<span class="token punctuation">.nodes<span class="token punctuation">.Element<span class="token punctuation">;
<span class="token keyword">import org<span class="token punctuation">.jsoup<span class="token punctuation">.select<span class="token punctuation">.Elements<span class="token punctuation">;
<span class="token keyword">import java<span class="token punctuation">.io<span class="token punctuation">.IOException<span class="token punctuation">;
<span class="token keyword">public <span class="token keyword">class <span class="token class-name">HTMLParserExample1 <span class="token punctuation">{
<span class="token keyword">public <span class="token keyword">static <span class="token keyword">void <span class="token function">main<span class="token punctuation">(String<span class="token punctuation">[<span class="token punctuation">] args<span class="token punctuation">) <span class="token punctuation">{
Document doc<span class="token punctuation">;
<span class="token keyword">try <span class="token punctuation">{
<span class="token comment">// need http protocol
doc <span class="token operator">= Jsoup<span class="token punctuation">.<span class="token function">connect<span class="token punctuation">(<span class="token string">"http://google.com"<span class="token punctuation">)<span class="token punctuation">.<span class="token function">get<span class="token punctuation">(<span class="token punctuation">)<span class="token punctuation">;
<span class="token comment">// get page title
String title <span class="token operator">= doc<span class="token punctuation">.<span class="token function">title<span class="token punctuation">(<span class="token punctuation">)<span class="token punctuation">;
System<span class="token punctuation">.out<span class="token punctuation">.<span class="token function">println<span class="token punctuation">(<span class="token string">"title : " <span class="token operator">+ title<span class="token punctuation">)<span class="token punctuation">;
<span class="token comment">// get all links
Elements links <span class="token operator">= doc<span class="token punctuation">.<span class="token function">select<span class="token punctuation">(<span class="token string">"a[href]"<span class="token punctuation">)<span class="token punctuation">;
<span class="token keyword">for <span class="token punctuation">(Element link <span class="token operator">: links<span class="token punctuation">) <span class="token punctuation">{
<span class="token comment">// get the value from href attribute
System<span class="token punctuation">.out<span class="token punctuation">.<span class="token function">println<span class="token punctuation">(<span class="token string">"\nlink : " <span class="token operator">+ link<span class="token punctuation">.<span class="token function">attr<span class="token punctuation">(<span class="token string">"href"<span class="token punctuation">)<span class="token punctuation">)<span class="token punctuation">;
System<span class="token punctuation">.out<span class="token punctuation">.<span class="token function">println<span class="token punctuation">(<span class="token string">"text : " <span class="token operator">+ link<span class="token punctuation">.<span class="token function">text<span class="token punctuation">(<span class="token punctuation">)<span class="token punctuation">)<span class="token punctuation">;
<span class="token punctuation">}
<span class="token punctuation">} <span class="token keyword">catch <span class="token punctuation">(<span class="token class-name">IOException e<span class="token punctuation">) <span class="token punctuation">{
e<span class="token punctuation">.<span class="token function">printStackTrace<span class="token punctuation">(<span class="token punctuation">)<span class="token punctuation">;
<span class="token punctuation">}
<span class="token punctuation">}
<span class="token punctuation">}
Output
link : http://www.google.com.my/imghp?hl=en&tab=wi
text : Imageslink : http://maps.google.com.my/maps?hl=en&tab=wl
text : Maps//omitted for readability
NoteIt’s recommended to specify a “userAgent
” in Jsoup,to avoid HTTP 403 error messages.
<pre class=" language-java"><code class=" language-java">Document doc <span class="token operator">= Jsoup<span class="token punctuation">.<span class="token function">connect<span class="token punctuation">(<span class="token string">"http://anyurl.com"<span class="token punctuation">)
<span class="token punctuation">.<span class="token function">userAgent<span class="token punctuation">(<span class="token string">"Mozilla"<span class="token punctuation">)
<span class="token punctuation">.<span class="token function">get<span class="token punctuation">(<span class="token punctuation">)<span class="token punctuation">;
2. Grabs All Images
The second example shows you how to use the Jsoup regex selector to grab all image files (png,jpg,gif) from “yahoo.com”.
<span class="token keyword">import org<span class="token punctuation">.jsoup<span class="token punctuation">.Jsoup<span class="token punctuation">;
<span class="token keyword">import org<span class="token punctuation">.jsoup<span class="token punctuation">.nodes<span class="token punctuation">.Document<span class="token punctuation">;
<span class="token keyword">import org<span class="token punctuation">.jsoup<span class="token punctuation">.nodes<span class="token punctuation">.Element<span class="token punctuation">;
<span class="token keyword">import org<span class="token punctuation">.jsoup<span class="token punctuation">.select<span class="token punctuation">.Elements<span class="token punctuation">;
<span class="token keyword">import java<span class="token punctuation">.io<span class="token punctuation">.IOException<span class="token punctuation">;