《简单的网页爬虫小程序》

这是一个简单的网页爬虫程序。其主要功能是获取指定网页中的邮箱地址。

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.URL;
import java.net.URLConnection;
import java.util.HashSet;
import java.util.Set;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class NetSpider {
	public static void main(String[] args) throws IOException {

		String str_url = "https://bbs.hcbbs.com/thread-1259140-1-1.html";// 提供网络地址的URL

		String regex = "\\w+@\\w+(\\.\\w+)+";// 匹配规则(使用正则表达式)(这个匹配邮箱的正则表达式只是一个宽泛的匹配模式)

		Set<String> set = getMailsByNet(str_url, regex);// getMailsByNet(str_url,regex)方法返回获得的邮件地址

		for (String string : set) {// 遍历set集合,打印遍历到的邮箱地址
			System.out.println(string);
		}
	}

	// 基于网络的获取邮件地址
	public static Set<String> getMailsByNet(String str_url, String regex)throws IOException {
		
		Set<String> set = new HashSet<String>();// 创建list集合
		
		URL url = new URL(str_url);// 将str_url封装成URL对象
		
		URLConnection conn = url.openConnection();// 打开连接
		
		InputStream in = conn.getInputStream();// 获取读取流
		BufferedReader bufIn = new BufferedReader(new InputStreamReader(in));
		
		Pattern p = Pattern.compile(regex);// 将正则表达式编译成对象
		
		String line = null;// 频繁读写操作
		while ((line = bufIn.readLine()) != null) {
			
			Matcher m = p.matcher(line);// 通过正则表达式对象获取匹配器
			while (m.find()) {// 把得到的邮箱存储到list集合中
				set.add(m.group());
			}
		}
		bufIn.close();// 关闭资源
		return set;
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值