閑來無事,剛學會把git部署到遠程服務器,沒事做,所以簡單做了一個抓取網頁信息的小工具,里面的一些數值如果設成參數的話可能擴展性能會更好!希望這是一個好的開始把,也讓我對字符串的讀取掌握的更加熟練了,值得注意的是JAVA1.8 里面在使用String拼接字符串的時候,會自動把你要拼接的字符串用StringBulider來處理,大大優化了String 的性能,閑話不多說,show my XXX code~
運行效果:
首先打開百度百科,搜索詞條,比如“演員”,再按F12查看源碼
然后抓取你想要的標簽,注入LinkedHashMap里面就ok了,很簡單是吧!看看代碼羅

1 import java.io.BufferedReader; 2 import java.io.IOException; 3 import java.io.InputStreamReader; 4 import java.net.HttpURLConnection; 5 import java.net.URL; 6 import java.util.*; 7 8 /** 9 * Created by chunmiao on 17-3-10. 10 */ 11 public class ReadBaiduSearch { 12 13 //儲存返回結果 14 private LinkedHashMap<String,String> mapOfBaike; 15 16 17 //獲取搜索信息 18 public LinkedHashMap<String,String> getInfomationOfBaike(String infomationWords) throws IOException { 19 mapOfBaike = getResult(infomationWords); 20 return mapOfBaike; 21 } 22 23 //通過網絡鏈接獲取信息 24 private static LinkedHashMap<String, String> getResult(String keywords) throws IOException { 25 //搜索的url 26 String keyUrl = "http://baike.baidu.com/search?word=" + keywords; 27 //搜索詞條的節點 28 String startNode = "<dl class=\"search-list\">"; 29 //詞條的鏈接關鍵字 30 String keyOfHref = "href=\""; 31 //詞條的標題關鍵字 32 String keyOfTitle = "target=\"_blank\">"; 33 34 String endNode = "</dl>"; 35 36 boolean isNode = false; 37 38 String title; 39 40 String href; 41 42 String rLine; 43 44 LinkedHashMap<String,String> keyMap = new LinkedHashMap<String,String>(); 45 46 //開始網絡請求 47 URL url = new URL(keyUrl); 48 HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection(); 49 InputStreamReader inputStreamReader = new InputStreamReader(urlConnection.getInputStream(),"utf-8"); 50 BufferedReader bufferedReader = new BufferedReader(inputStreamReader); 51 52 //讀取網頁內容 53 while ((rLine = bufferedReader.readLine()) != null){ 54 //判斷目標節點是否出現 55 if(rLine.contains(startNode)){ 56 isNode = true; 57 } 58 //若目標節點出現,則開始抓取數據 59 if (isNode){ 60 //若目標結束節點出現,則結束讀取,節省讀取時間 61 if (rLine.contains(endNode)) { 62 //關閉讀取流 63 bufferedReader.close(); 64 inputStreamReader.close(); 65 break; 66 } 67 //若值為空則不讀取 68 if (((title = getName(rLine,keyOfTitle)) != "") && ((href = getHref(rLine,keyOfHref)) != "")){ 69 keyMap.put(title,href); 70 } 71 } 72 } 73 return keyMap; 74 } 75 76 //獲取詞條對應的url 77 private static String getHref(String rLine,String keyOfHref){ 78 String baikeUrl = "http://baike.baidu.com"; 79 String result = ""; 80 if(rLine.contains(keyOfHref)){ 81 //獲取url 82 for (int j = rLine.indexOf(keyOfHref) + keyOfHref.length();j < rLine.length()&&(rLine.charAt(j) != '\"');j ++){ 83 result += rLine.charAt(j); 84 } 85 //獲取的url中可能不含baikeUrl,如果沒有則在頭部添加一個 86 if(!result.contains(baikeUrl)){ 87 result = baikeUrl + result; 88 } 89 } 90 return result; 91 } 92 93 //獲取詞條對應的名稱 94 private static String getName(String rLine,String keyOfTitle){ 95 String result = ""; 96 //獲取標題內容 97 if(rLine.contains(keyOfTitle)){ 98 result = rLine.substring(rLine.indexOf(keyOfTitle) + keyOfTitle.length(),rLine.length()); 99 //將標題中的內容含有的標簽去掉 100 result = result.replaceAll("<em>|</em>|</a>|<a>",""); 101 } 102 return result; 103 } 104 105 }
現在都好晚了,去睡覺了...