[code]使用正則擷取網頁裡的特定內容

來源:互聯網
上載者:User


: 代碼1的正則將會在html裡迴圈尋找,代碼2的正則只會尋找第一個匹配的項

 

代碼1:

package utils.net;<br />import java.io.BufferedReader;<br />import java.io.IOException;<br />import java.io.InputStreamReader;<br />import java.net.MalformedURLException;<br />import java.net.URL;<br />import java.util.ArrayList;<br />import java.util.List;<br />import java.util.regex.Matcher;<br />import java.util.regex.Pattern;<br />/**<br /> * 學習使用<br /> *<br /> * @author loocao<br /> *<br /> * (代碼無著作權,歡迎強姦)<br /> */<br />public class LoadWebSite1 {<br />/**<br /> * @param args<br /> */<br />public static void main(String[] args) {<br />String url = "http://www.qx121.com/web/plug/weather2.asp";<br />String html = getHtml(url);<br />System.out.println(html);<br />System.out.println();<br />String s[] = queryString(html,<br />"<a target=/"_blank/" href=/".{20}/" >(.{2,100})</a>");<br />for (String str : s) {<br />System.out.println(str);<br />}<br />}<br />/**<br /> * 擷取url的HTML內容 <br/><br /> * URL的使用方法是在網上找到的,瞭解更多,請參考Apache Client<br /> *<br /> * @param url<br /> * @return<br /> */<br />public static String getHtml(String url) {<br />StringBuffer html = new StringBuffer();<br />try {<br />URL u = new URL(url);<br />BufferedReader reader = new BufferedReader(new InputStreamReader(u<br />.openStream()));<br />String temp;<br />while ((temp = reader.readLine()) != null) {<br />html.append(temp);<br />}<br />} catch (MalformedURLException e) {<br />e.printStackTrace();<br />} catch (IOException e) {<br />e.printStackTrace();<br />}<br />return html.toString();<br />}<br />/**<br /> * 根據regex尋找字串<br /> *<br /> * @param html<br /> * @param regex<br /> * @return<br /> */<br />public static String[] queryString(String html, String regex) {<br />Pattern p = Pattern.compile(regex);<br />Matcher m = p.matcher(html);<br />List<String> list = new ArrayList<String>();<br />while (m.find()) {<br />for (int i = 0; i < m.groupCount(); i++) {<br />list.add(m.group(i + 1));<br />}<br />}<br />return list.toArray(new String[list.size()]);<br />}<br />}<br />

 

代碼2:

package utils.net;<br />import java.io.BufferedReader;<br />import java.io.IOException;<br />import java.io.InputStreamReader;<br />import java.net.MalformedURLException;<br />import java.net.URL;<br />import java.util.regex.Matcher;<br />import java.util.regex.Pattern;<br />/**<br /> * 學習使用<br /> *<br /> * @author loocao<br /> *<br /> * (代碼無著作權,歡迎強姦)<br /> */<br />public class LoadWebSite2 {<br />/**<br /> * @param args<br /> */<br />public static void main(String[] args) {<br />String url = "http://www.qx121.com/web/plug/weather2.asp";<br />String html = getHtml(url);<br />System.out.println(html);<br />System.out.println();<br />String[] s = queryString(<br />html,<br />"<a target=/"_blank/" href=/".{0,255}/" >"<br />+ "(.{4,20})</a></td> <td height=/"20/" "<br />+ "align=/"center/" valign=/"middle/">"<br />+ "<a target=/"_blank/" href=/".{0,255}/" >"<br />+ "(.{2,10})</a></td> <td height=/"20/" "<br />+ "align=/"center/" valign=/"middle/">"<br />+ "<a target=/"_blank/" href=/".{0,255}/" >"<br />+ "(.{4,100})</a>");<br />for (String str : s) {<br />System.out.println(str);<br />}<br />}<br />/**<br /> * 擷取url的HTML內容 <br/><br /> * URL的使用方法是在網上找到的,瞭解更多,請參考Apache Client<br /> *<br /> * @param url<br /> * @return<br /> */<br />public static String getHtml(String url) {<br />StringBuffer html = new StringBuffer();<br />try {<br />URL u = new URL(url);<br />BufferedReader reader = new BufferedReader(new InputStreamReader(u<br />.openStream()));<br />String temp;<br />while ((temp = reader.readLine()) != null) {<br />html.append(temp);<br />}<br />} catch (MalformedURLException e) {<br />e.printStackTrace();<br />} catch (IOException e) {<br />e.printStackTrace();<br />}<br />return html.toString();<br />}<br />/**<br /> * 根據regex尋找字串<br /> *<br /> * @param html<br /> * @param regex<br /> * @return<br /> */<br />public static String[] queryString(String html, String regex) {<br />Pattern p = Pattern.compile(regex);<br />Matcher m = p.matcher(html);<br />String s[] = new String[m.groupCount()];<br />if (m.find()) {<br />for (int i = 0; i < s.length; i++) {<br />s[i] = m.group(i + 1);<br />}<br />}<br />return s;<br />}<br />}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.