经过一周的挣扎,目前天气预报抓取解析插入数据库的功能已经大致实现,附项目源码

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:
 

将中国天气网近六天(因为有些城市提供的数据源只有五天数据,所以我暂时取5天,程序里依然是六天的标准)的天气情况抓取,用JSON解析,存入数据库,数据库是两张表,城市表和天气表。程序可以运行,两个表都能读入数据,城市表大致读入了423行数据,天气表大致读入了1800行数据。程序的缺点在于,暂时还没写注释,面向对象还未体现,没有实现每天定时抓取的性能,需要人工每天手动运行程序抓取数据。。。。。

 

附源码:

http://download.csdn.net/detail/opzoonzhuzhengke/3860118


刚才实现了一下定时抓取

不贴代码了,大致看下这个例子,改吧改吧就行了

import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;

public class Tim {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		Timer tt=new Timer();
		TimerTaskMine tk=new TimerTaskMine();
		System.out.println((new Date()).toString());
		tt.schedule(tk, 1000*5, 1000*2);//第一次先等待5秒,以后每隔2秒走一次run方法。
		
//		tt.schedule(tk, 1000*3);//等待3秒,然后只执行1次。
		
		
	}

}


class TimerTaskMine extends TimerTask{
	int i=0;
	int kkk=0;

	@Override
	public void run() {
		i++;kkk++;
		// TODO Auto-generated method stub
		System.out.println((new Date()).toString()+"--i--"+i+"--kkk--"+kkk);
		try {
			Thread.sleep(1000*4);//这句代码,把schedule(1,2,3)第3个参数覆盖掉了,
			//这里是4秒,即使你在schedule方法中这的是2秒也使用4秒
			
			if(this.i==5){
				this.cancel();
			}
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
	
}

Timer类就像一个定时器,用于设置特定的时间或周期,来配合线程动作的执行,但是只调用Timer无法执行线程动作,必须配合另一个类TimerTask的方法才能使用。从示例6-13中可以发现Timer类与Thread类很相近。

public Timer ()

创建一个新的timer对象。

Timer属于计时器类,Time建立后,需要调用schedule()方法来执行计划任务,计划调度的方法有许多运用方式:

public void schedule (TimerTask task, long delay)

执行任务前先等待一段时间。task代表要执行的任务,delay代表需要等待的时间,单位为毫秒(1000毫秒为1秒)。

 

 

public void schedule (TimerTask task,Date time)

在指定的系统时间time之后开始执行任务。

 

 

public void schedule (TimerTask task,long delay,long period)

延迟一段时间后开始执行任务,任务按照设定的周期执行。传入的参数:delay为延迟时间,period为周期时间,单位均为毫秒。

 

 

public void schedule(TimerTask task,Date firstTime,long period)

在指定的时间后开始执行任务,任务按照设定的周期执行。传入的参数:firstTime为指定等待时间,period为周期时间,单位都是毫秒。

 

 

public void scheduleAtFixedRate (TimerTask task,long delay,long period)

执行任务内容后,等待delay时间,再按照period周期时间继续执行任务,单位都是毫秒。

 

 

public void scheduleAtFixedRate(TimerTask task,Date firstTime,long period)

先等待一段时间firstTime,再执行计划任务,然后按照period周期时间继续执行任务,单位都是毫秒。

 

 

public void cancel()

停止timer计时。

 

有了Timer的各项调用方法,还不能直接执行计划任务,需要跟TimerTask类共同运用才能使计划任务开始运行。TimerTask所包含的相关方法如下:

public void TimerTask ()

创建一个新的TimerTask对象。

 

public abstract void run()

运行计划任务的工作内容。

 

public void cancel()

中止TimerTask类的执行流程,不再执行所调度的工作内容。

 

public void scheduleExcutionTime()

实际运行计划任务所用的时间。


目录
相关文章
|
8天前
|
数据库 索引
深入探索数据库索引技术:回表与索引下推解析
【10月更文挑战第15天】在数据库查询优化的领域中,回表和索引下推是两个核心概念,它们对于提高查询性能至关重要。本文将详细解释这两个术语,并探讨它们在数据库操作中的作用和影响。
30 3
|
14天前
|
存储 NoSQL 关系型数据库
数据库技术深度解析:从基础到进阶
【10月更文挑战第17天】数据库技术深度解析:从基础到进阶
36 0
|
7天前
|
存储 负载均衡 监控
数据库多实例的深入解析
【10月更文挑战第24天】数据库多实例是一种重要的数据库架构方式,它为数据库的高效运行和灵活管理提供了多种优势。在实际应用中,需要根据具体的业务需求和技术环境,合理选择和配置多实例,以充分发挥其优势,提高数据库系统的性能和可靠性。随着技术的不断发展和进步,数据库多实例技术也将不断完善和创新,为数据库管理带来更多的可能性和便利。
83 57
|
2天前
|
SQL Java 数据库连接
深入 MyBatis-Plus 插件:解锁高级数据库功能
Mybatis-Plus 提供了丰富的插件机制,这些插件可以帮助开发者更方便地扩展 Mybatis 的功能,提升开发效率、优化性能和实现一些常用的功能。
51 26
深入 MyBatis-Plus 插件:解锁高级数据库功能
|
4天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
14 3
|
3天前
|
PHP 数据库 数据安全/隐私保护
布谷直播源码部署服务器关于数据库配置的详细说明
布谷直播系统源码搭建部署时数据库配置明细!
|
7天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
41 2
|
5天前
|
XML 数据库 数据格式
数据库 校验名称唯一性,用于新增和修改功能
数据库 校验名称唯一性,用于新增和修改功能
18 1
|
14天前
|
SQL JavaScript 关系型数据库
node博客小项目:接口开发、连接mysql数据库
【10月更文挑战第14天】node博客小项目:接口开发、连接mysql数据库
|
21天前
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。

热门文章

最新文章

推荐镜像

更多