基于Java的数据采集(一)
之前写过2篇关于PHP数据采集入库的文章:
基于PHP数据采集入库(一):http://www.cnblogs.com/lichenwei/p/3872307.html
基于PHP数据采集入库(二):http://www.cnblogs.com/lichenwei/p/3873281.html
《基于Java的数据采集(二)》:http://www.cnblogs.com/lichenwei/p/3905370.html
《基于Java数据采集入库(三)》:http://www.cnblogs.com/lichenwei/p/3907007.html
《基于Java数据采集入库(终结篇)》:http://www.cnblogs.com/lichenwei/p/3910492.html
其实采集的原理都是一样的:远程获取信息->提取所需内容(正则)->分类存储->读取->展示
用什么编程语言没所谓,编程语言只是种工具
这次来采集一个足球网站的数据:http://www.footballresults.org/league.php?league=EngDiv1
下图是我们要采集的数据:


好了,关于采集原理就看上面那2篇文章吧,剩下的直接上代码:
GerData.java(采集数据方法封装)
其实也就是简单的匹配正则:
group():返回在以前匹配操作期间由给定组捕获的输入子序列。
find():尝试查找与该模式匹配的输入序列的下一个子序列。
package com.lcw.curl;
import java.util.regex.Matcher;
import java.util.regex.Pattern; public class GetData { /**
*
* @param regex 正则表达式
* @param content 所要匹配的内容
* @return
*/
public String getData(String regex,String content){
Pattern pattern=Pattern.compile(regex, Pattern.CASE_INSENSITIVE);//设定正则表达式,不区分大小写
Matcher matcher=pattern.matcher(content);
if(matcher.find()){
return matcher.group();
}else{
return "";
}
} }
CurlMain.java(主程序)
InputStreamReader()是字节流通向字符流的桥梁。
InputStreamReader()是字节流通向字符流的桥梁。
openStream()打开到此URL的连接并返回一个用于从该连接读入的字节流。
package com.lcw.curl; import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.URL; public class CurlMain { /**
* @param args
*/
public static void main(String[] args) {
try {
String address="http://www.footballresults.org/league.php?league=EngDiv1";
URL url=new URL(address);
InputStreamReader inputStreamReader=new InputStreamReader(url.openStream(),"utf-8");//打开地址,以UTF-8编码的形式返回字节并转为字符
BufferedReader bufferedReader=new BufferedReader(inputStreamReader);//从字符输入流中读取文本,缓冲各个字符,从而提供字符、数组和行的高效读取。 GetData data=new GetData();
String content="";//用来接受每次读取的行字符
int flag=0;//标志,队伍信息刚好在日期信息后面,则正则相同,用于分离数据
String dateRegex="\\d{1,2}\\.\\d{1,2}\\.\\d{4}";//日期匹配正则表达式
String teamRegex=">[^<>]*</a>";//队伍匹配正则表达式
String scoreRegex=">(\\d{1,2}-\\d{1,2})</TD>";//比分正则表达式
int i=0;//记录信息条数 while((content=bufferedReader.readLine())!=null){//每次读取一行数据
//获取比赛日期信息
String dateInfo=data.getData(dateRegex, content);
if(!dateInfo.equals("")){
System.out.println("日期:"+dateInfo);
flag++;
}
//获取队伍信息,需先读到日期信息让标志符自增
String teamInfo=data.getData(teamRegex, content);
if(!teamInfo.equals("")&&flag==1){
teamInfo=teamInfo.substring(1, teamInfo.indexOf("</a>"));
System.out.println("主队:"+teamInfo);
flag++;
}else if (!teamInfo.equals("") && flag == 2) {
teamInfo = teamInfo.substring(1, teamInfo.indexOf("</a>"));
System.out.println("客队:" + teamInfo);
flag = 0;
}
//获取比分信息
String scoreInfo=data.getData(scoreRegex, content);
if(!scoreInfo.equals("")){
scoreInfo=scoreInfo.substring(1, scoreInfo.indexOf("</TD>"));
System.out.println("比分:"+scoreInfo);
System.out.println();
i++;
} }
bufferedReader.close();
System.out.println("一共收集到了"+i+"条信息");
} catch (Exception e) {
e.printStackTrace();
} } }
数据轻松采集,效果如下图:


基于Java的数据采集(一)的更多相关文章
- 基于Java的数据采集(二)
在上一篇文章<基于Java的数据采集(一)>:http://www.cnblogs.com/lichenwei/p/3904715.html 提到了如何如何读取网页源代码,并通过group ...
- 基于Java的数据采集(三)
<基于Java的数据采集(一)>:http://www.cnblogs.com/lichenwei/p/3904715.html <基于Java的数据采集(二)>:http:/ ...
- 基于Java的数据采集(终结篇)
关于写过关于JAVA采集入库的三篇文章: 基于Java数据采集入库(一):http://www.cnblogs.com/lichenwei/p/3904715.html 基于Java数据采集入库(二) ...
- 基于Java Mina框架的部标jt808服务器设计和开发
在开发部标GPS平台中,部标jt808GPS服务器是系统的核心关键,决定了部标平台的稳定性和行那个.Linux服务器是首选,为了跨平台,开发语言选择Java自不待言.需要购买jt808GPS服务器源码 ...
- 9个基于Java的搜索引擎框架
在这个信息相当繁杂的互联网时代,我们已经学会了如何利用搜索引擎这个强大的利器来找寻目标信息,比如你会在Google上搜索情人节如何讨女朋友欢心,你也会在百度上寻找正规的整容医疗机构(尽管有很大一部分广 ...
- 基于java平台的常用资源整理
这里整理了基于java平台的常用资源 翻译 from :akullpp | awesome-java 大家一起学习,共同进步. 如果大家觉得有用,就mark一下,赞一下,或评论一下,让更多的人知道.t ...
- 基于Java的打包jar、war、ear包的作用与区别详解
本篇文章,小编为大家介绍,基于Java的打包jar.war.ear包的作用与区别详解.需要的朋友参考下 以最终客户的角度来看,JAR文件就是一种封装,他们不需要知道jar文件中有多少个.cla ...
- 基于Java Netty框架构建高性能的部标808协议的GPS服务器
使用Java语言开发一个高质量和高性能的jt808 协议的GPS通信服务器,并不是一件简单容易的事情,开发出来一段程序和能够承受数十万台车载接入是两码事,除去开发部标808协议的固有复杂性和几个月长周 ...
- 基于Java Mina框架的部标808服务器设计和开发
在开发部标GPS平台中,部标808GPS服务器是系统的核心关键,决定了部标平台的稳定性和行那个.Linux服务器是首选,为了跨平台,开发语言选择Java自不待言. 我们为客户开发的部标服务器基于Min ...
随机推荐
- yum 安装 jenkins
环境:已安装 tomcat 安装(如果yum下载速度比较忙可以下载下来再安装) yum -y install https://pkg.jenkins.io/redhat/jenkins-2.77-1. ...
- thinkphp5 学习笔记
一.开发规范: 二.API: 1.数据输出:新版的控制器输出采用 Response 类统一处理,而不是直接在控制器中进行输出,通过设置 default_return_type 就可以自动进行数据转换处 ...
- failed to initialize unity graphics 错误解决方法(win7 unity4.x)
重装系统后 unity 4.7.2安装之后,破解完毕就有了个Fatal error; 提示信息为:failed to initialize unity graphics 解决办法:依旧是先查看了网上 ...
- 使用C3P0报错:java.lang.NoClassDefFoundError: com/mchange/v2/ser/Indirector
错误提示: java.lang.NoClassDefFoundError: com/mchange/v2/ser/Indirector at JDBC.ConnectionPool.testC3P0( ...
- nginx编译安装on mac
一.编译安装模块 如果是原有包中就有的模块,编译时, ./configure --with-xxx 就可以, 如果是第三方模块,可使用 --add-module, 如果有多个模块的话,只需要多次使用- ...
- C# ConcurrentQueue实现
我们从C# Queue 和Stack的实现知道Queue是用数组来实现的,数组的元素不断的通过Array.Copy从一个数组移动到另一个数组,ConcurrentQueue我们需要关心2点:1线程安全 ...
- SoapUI Pro Project Solution Collection-change the JDBC Request behavior
change the jdbc request : 1.change the driver name,connection string,query string or assert. the obj ...
- Android——TabHost(标签容器)相关知识总结贴
android 2.3 r1 中文 api (58) —— TabHost http://www.apkbus.com/android-18911-1-1.html android中文api (5 ...
- 【Linux】使用w命令和uptime命令查看系统负载
在Linux系统中查询系统CPU和内存的负载(使用率)时,我们通常习惯于使用top.atop或者ps,这篇文章将要给大家介绍如何使用w命令和uptime命令来查看系统的负载情况,对于uptime命令, ...
- CentOS7.4安装配置mysql8 TAR免安装版
下载mysql: https://dev.mysql.com/downloads/mysql/ 解压tar.xz文件:先 xz -d mysql-8.0.15-linux-glibc2.12-x86_ ...