• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Java > java 爬虫详解及简单实例

java 爬虫详解及简单实例

作者:饭饭_fan 字体:[增加 减小] 来源:互联网 时间:2017-05-28

饭饭_fan 通过本文主要向大家介绍了java网络爬虫实例,java爬虫实例,网络爬虫java,java爬虫代码,网络爬虫代码 java等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

Java爬虫

一、代码

爬虫的实质就是打开网页源代码进行匹配查找,然后获取查找到的结果。

打开网页:

URL url = new URL(http://www.cnblogs.com/Renyi-Fan/p/6896901.html);
</div>

读取网页内容:

BufferedReader bufr = new BufferedReader(new InputStreamReader(url.openStream()));
</div>

正则表达式进行匹配:

tring mail_regex = "\\w+@\\w+(\\.\\w+)+";
</div>

储存结果:

List<String> list = new ArrayList<String>();
</div>

/*
* 获取
* 将正则规则进行对象的封装。
* Pattern p = Pattern.compile("a*b");
* //通过正则对象的matcher方法字符串相关联。获取要对字符串操作的匹配器对象Matcher .
* Matcher m = p.matcher("aaaaab");
* //通过Matcher匹配器对象的方法对字符串进行操作。
* boolean b = m.matches();
*/

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Spider {

  public static void main(String[] args) throws IOException {
//    List<String> list = getMails();
//    for(String mail : list){
//      System.out.println(mail);
//    }
  
    List<String> list = getMailsByWeb();
    for(String mail : list){
      System.out.println(mail);
    }
  }

  public static List<String> getMailsByWeb() throws IOException{
    //1,读取源文件。
    //URL url = new URL("http://192.168.1.100:8080/myweb/mail.html");
    //URL url = new URL("http://localhost:8080/SecondWeb/index.jsp");
    URL url = new URL("http://www.cnblogs.com/Renyi-Fan/p/6896901.html");

    BufferedReader bufr = new BufferedReader(new InputStreamReader(url.openStream()));


    //2,对读取的数据进行规则的匹配。从中获取符合规则的数据.
    String mail_regex = "\\w+@\\w+(\\.\\w+)+";

    List<String> list = new ArrayList<String>();

    Pattern p = Pattern.compile(mail_regex);
    String line = null;

    while((line=bufr.readLine())!=null){

      Matcher m = p.matcher(line);
      while(m.find()){
        //3,将符合规则的数据存储到集合中。
        list.add(m.group());
      }

    }
    return list;
  }

  public static List<String> getMails() throws IOException{
    //1,读取源文件。
    BufferedReader bufr = new BufferedReader(new FileReader("c:\\mail.html"));


    //2,对读取的数据进行规则的匹配。从中获取符合规则的数据.
    String mail_regex = "\\w+@\\w+(\\.\\w+)+";

    List<String> list = new ArrayList<String>();

    Pattern p = Pattern.compile(mail_regex);
    String line = null;

    while((line=bufr.readLine())!=null){

      Matcher m = p.matcher(line);
      while(m.find()){
        //3,将符合规则的数据存储到集合中。
        list.add(m.group());
      }

    }
    return list;
  }
}

</div>

二、运行结果

abc1@sina.com.cn
1@1.1
</div>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • java 爬虫详解及简单实例
  • Java从网络读取图片并保存至本地实例
  • java 爬虫详解及简单实例
  • Java从网络读取图片并保存至本地实例

相关文章

  • 2017-05-28Java中自定义异常详解及实例代码
  • 2017-05-28Spring依赖注入的两种方式(根据实例详解)
  • 2017-05-28java反射遍历实体类属性和类型,并赋值和获取值的简单方法
  • 2017-05-28jstl之map,list访问遍历以及el表达式map取值的实现
  • 2017-05-28Java中ArrayList去除重复元素(包括字符串和自定义对象)
  • 2017-05-28详解Java 自动装箱与拆箱的实现原理
  • 2017-05-28Java数组的特性_动力节点Java学院整理
  • 2017-05-28Java容器HashMap与HashTable详解
  • 2017-05-28JAVA用户自定义事件监听实例代码
  • 2017-05-28MyBatis简介与配置MyBatis+Spring+MySql的方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • MyBatis关于二级缓存问题
    • spring boot整合RabbitMQ实例详解(Fanout模式)
    • Java装饰器设计模式_动力节点Java学院整理
    • java HashSet深入理解
    • Mybatis接口式编程的原理
    • 详解Spring Data操作Redis数据库
    • JAVA实现JSON后端向前端传递数据
    • Java String对象使用方法详解
    • Java关键字this(动力节点Java学院整理)
    • JAVA Frame 窗体背景图片,首位相接滚动代码实例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有