java利用url实现网页内容的抓取
作者:zangcunmiao 时间:2023-05-14 11:10:21
闲来无事,刚学会把git部署到远程服务器,没事做,所以简单做了一个抓取网页信息的小工具,里面的一些数值如果设成参数的话可能扩展性能会更好!希望这是一个好的开始把,也让我对字符串的读取掌握的更加熟练了,值得注意的是JAVA1.8 里面在使用String拼接字符串的时候,会自动把你要拼接的字符串用StringBulider来处理,大大优化了String 的性能,闲话不多说,show my XXX code~
运行效果:
首先打开百度百科,搜索词条,比如“演员”,再按F12查看源码
然后抓取你想要的标签,注入LinkedHashMap里面就ok了,很简单是吧!看看代码罗
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;
}
}
来源:http://www.cnblogs.com/sospopo/p/6533797.html
标签:java,抓取
0
投稿
猜你喜欢
springBoot+dubbo+zookeeper实现分布式开发应用的项目实践
2021-11-22 02:03:25
Java Synchronized的偏向锁详细分析
2021-07-09 00:35:23
深入了解ViewPager2的使用
2021-07-06 17:26:26
Android编程实现使用webView打开本地html文件的方法
2023-04-26 14:30:38
Java编程泛型限定代码分享
2023-11-09 17:46:32
Android Flutter实现仿闲鱼动画效果
2023-07-15 15:32:47
C# SQLite执行效率的优化教程
2021-07-11 00:11:41
搭建简单的Spring-Data JPA项目
2023-04-05 01:06:30
C#键盘鼠标钩子实例
2021-10-18 21:05:24
在C#中捕获内存不足异常
2021-07-14 11:50:46
C# 爬虫简单教程
2022-04-24 14:10:53
java对double数组排序示例分享
2022-07-13 03:22:14
C#并行编程之信号量
2023-10-08 19:26:54
JAVA图片水印开发案例详解
2023-06-20 02:06:53
ActiveMQ结合Spring收发消息的示例代码
2023-11-24 06:01:12
JAVA中的final关键字用法实例详解
2021-06-25 12:10:08
Java并发之ReentrantLock类源码解析
2022-08-09 18:10:35
Java源码解析之Iterable接口
2023-04-17 08:06:57
C#中FileStream的对比及使用方法
2023-10-17 21:09:41
VS2013创建Windows服务与调试服务的图文方法
2022-01-15 02:23:14