基于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 ...
随机推荐
- java获取在各种编码下中文及英文的字符个数
https://blog.csdn.net/cuker919/article/details/17281691
- sessions
php session 用于存储有关用户回话的相关信息,或更改用户会话的相关设置,session变量保存的信息是单一用户的,并且可供应用程序中所有页面使用 session 的工作机制:为每个访问者创建 ...
- Linux 下建立 Git 与 GitHub 的连接
Git 是一款开源的分布式版本控制系统,而 GitHub 是依托 Git 的代码托管平台. GitHub 利用 Git 极其强大的克隆和分支功能,使得社区成员能够自由地参与到开源项目中去. 不过,在开 ...
- Linux下刷新DNS缓存(Ubuntu/CentOS)
现在很多Linux发行版都没有内置DNS本地缓存,Linux不像Windows那样可以使用ipconfig /flushdns来刷新,在Linux下无需刷新,因为本身没有缓存: 当然,如果非要缓存刷新 ...
- java判断传进来的是否是图片
public static void main(String[] args) throws IOException { String filePath = "C:\\Users\\80975 ...
- 关于Segmentation fault (core dumped)
有的程序可以通过编译,但在运行时会出现Segment fault(段错误).这通常都是指针错误引起的.但这不像编译错误一样会提示到文件一行,而是没有任何信息.一种办法是用gdb的step, 一步一步寻 ...
- C# 备份、还原、拷贝远程文件夹
最近一直都很忙,非常抱歉好久没有写过博客了.最近遇到拷贝远程文件的一些工作,比如我们发布的web站点的时候,开发提供一个zip压缩包,我们需要上传到远程的服务器A,然后在部署(文件拷贝)到远程环境B和 ...
- Java读取Unicode文件(UTF-8等)时碰到的BOM首字符问题,及处理方法
转载:https://blog.csdn.net/clementad/article/details/47168573 2015-18-01修改:增加 apache commons io 处理方法. ...
- centos7安装配置mysql5.6
1. 下载mysql的repo源 $ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm 2. 安装mysql-co ...
- android highcharts 柱状图例子
android提供achartengine api 只能做简单的,如果是复杂的图表,个人的想法结合highcharts来完成:减小工作量,官方提供的例子也非常丰富. 通过android webview ...