자바 url 을 이용 하여 웹 페이지 내용 캡 처 실현
실행 효과:
먼저 바 이 두 백 과 를 열 고'배우'와 같은 단 어 를 검색 한 다음 에 F12 를 누 르 면 소스 코드 를 볼 수 있 습 니 다.
그리고 원 하 는 탭 을 잡 아서 링크 드 해시 맵 에 넣 으 면 돼 요.간단 하 죠?코드 봐 봐.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.*;
/**
* Created by chunmiao on 17-3-10.
*/
public class ReadBaiduSearch {
//
private LinkedHashMap<String,String> mapOfBaike;
//
public LinkedHashMap<String,String> getInfomationOfBaike(String infomationWords) throws IOException {
mapOfBaike = getResult(infomationWords);
return mapOfBaike;
}
//
private static LinkedHashMap<String, String> getResult(String keywords) throws IOException {
// url
String keyUrl = "http://baike.baidu.com/search?word=" + keywords;
//
String startNode = "<dl class=\"search-list\">";
//
String keyOfHref = "href=\"";
//
String keyOfTitle = "target=\"_blank\">";
String endNode = "</dl>";
boolean isNode = false;
String title;
String href;
String rLine;
LinkedHashMap<String,String> keyMap = new LinkedHashMap<String,String>();
//
URL url = new URL(keyUrl);
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
InputStreamReader inputStreamReader = new InputStreamReader(urlConnection.getInputStream(),"utf-8");
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
//
while ((rLine = bufferedReader.readLine()) != null){
//
if(rLine.contains(startNode)){
isNode = true;
}
// ,
if (isNode){
// , ,
if (rLine.contains(endNode)) {
//
bufferedReader.close();
inputStreamReader.close();
break;
}
//
if (((title = getName(rLine,keyOfTitle)) != "") && ((href = getHref(rLine,keyOfHref)) != "")){
keyMap.put(title,href);
}
}
}
return keyMap;
}
// url
private static String getHref(String rLine,String keyOfHref){
String baikeUrl = "http://baike.baidu.com";
String result = "";
if(rLine.contains(keyOfHref)){
// url
for (int j = rLine.indexOf(keyOfHref) + keyOfHref.length();j < rLine.length()&&(rLine.charAt(j) != '\"');j ++){
result += rLine.charAt(j);
}
// url baikeUrl,
if(!result.contains(baikeUrl)){
result = baikeUrl + result;
}
}
return result;
}
//
private static String getName(String rLine,String keyOfTitle){
String result = "";
//
if(rLine.contains(keyOfTitle)){
result = rLine.substring(rLine.indexOf(keyOfTitle) + keyOfTitle.length(),rLine.length());
//
result = result.replaceAll("<em>|</em>|</a>|<a>","");
}
return result;
}
}
이상 은 본 고의 모든 내용 입 니 다.본 고의 내용 이 여러분 의 학습 이나 업무 에 어느 정도 도움 이 되 기 를 바 랍 니 다.또한 저 희 를 많이 지지 해 주시 기 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Is Eclipse IDE dying?In 2014 the Eclipse IDE is the leading development environment for Java with a market share of approximately 65%. but ac...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.