• 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微信公众平台开发(2) 微信服务器post消息体的接收
  • 2017-05-28Java常用字符串工具类 字符串智能截取(3)
  • 2017-05-28java基础中异常及包归纳整理
  • 2017-05-28SpringMVC中解决@ResponseBody注解返回中文乱码问题
  • 2017-05-28Java实现一个达达租车系统的步骤详解
  • 2017-05-28CentOS安装solr 4.10.3详细教程
  • 2017-05-28Hibernate三种状态和Session常用的方法
  • 2017-05-28Java synchronized关键_动力节点Java学院整理
  • 2017-05-28JVM 方法调用之静态分派(详解)
  • 2017-05-28SpringBoot webSocket实现发送广播、点对点消息和Android接收

文章分类

  • 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面试题之try中含return语句时代码的执行顺序详解
    • 如何把spring boot项目部署到tomcat容器中
    • java 算法二分查找和折半查找
    • Java 中的Printstream介绍_动力节点Java学院整理
    • Java微信公众平台开发(8) 多媒体消息回复
    • java实现短信通信的完整教程
    • Java 7大常见排序方法实例详解
    • java中的Struts2拦截器详解
    • 通过JDBC连接oracle数据库的十大技巧

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

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