先复制GuPiao2.txt (更新后的数据)的内容到GuPiao1.txt(暂存)再将网页数据抓取存入GuPiao.txt
取GuPiao.txt 的行的时间与GuPiao1.txt的行的时间进行比较,将新数据存入GuPiao2.txt.
方法是自己探索编写的,发现很笨拙存在较大问题,将尝试换思路考虑另外可行的方法
经验小结:先有全局的构思和清晰的思路是很重要的,在没有好的建模思想和在含糊的思路下出来的代码,后果将比想象中的严重,不但会花费更多的时间,而且导致代码难以阅读和完善
/*
* import java.io.BufferedReader;
* import java.io.File;
* import java.io.FileReader;
* import java.io.IOException;
* import java.util.regex.Matcher;
* import java.util.regex.Pattern;
*/
import java.net.*;
import java.io.*;
import java.util.regex.*;
import java.util.Scanner;
public class DataUpdate{
public static void main(String[] args) throws IOException {
Scanner sc = new Scanner(System.in);
String s;
String str = null;
String str1 = null;
int daima;
int year;
int jidu;
int i = 0;
int j = 0 ;
System.out.println("输入股票代码");
daima = sc.nextInt();
System.out.println("输入要插入的年份");
year = sc.nextInt();
System.out.println("输入要插入的季度");
jidu = sc.nextInt();
//网页地址
//根据输入的股票代码插入的年份和季度进行查找
URL gupiao = new URL("http://money.finance.sina.com.cn/corp/go.php/vMS_MarketHistory/stockid/" + daima +".phtml?year=" + year + "&jidu=" + jidu);
//创建输入流
BufferedReader br = new BufferedReader(new InputStreamReader(gupiao.openStream()));
//复制GuPiao.txt到GuPiao1.txt
//创建输出文档
FileOutputStream fosout = new FileOutputStream("D:\\XiAoOMAn\\GuPiao1.txt");
File file=new File("D:\\XiAoOMAn\\GuPiao.txt");//
FileReader fr=new FileReader(file);//创建文件输入流
BufferedReader in=new BufferedReader(fr);//包装文件输入流,整行读取
OutputStreamWriter owsout = new OutputStreamWriter(fosout);
while ((str = in.readLine()) != null){
owsout.write(str);
owsout.write("\r\n") ;
}
owsout.close();
fosout.close();//保存gupiao1.txt,关闭
FileOutputStream fos = new FileOutputStream("D:\\XiAoOMAn\\GuPiao.txt");
FileOutputStream fosreason = new FileOutputStream("D:\\XiAoOMan\\Gupiao2.txt");
//创建输出流
OutputStreamWriter ows = new OutputStreamWriter(fos);
OutputStreamWriter owsreason = new OutputStreamWriter(fosreason);
//匹配需要获取的数据的列名
Pattern q = Pattern.compile("((?<=g>)(\\w*?)).*?(?=(</strong>))");
//匹配数据
Pattern p = Pattern.compile("((?<=date=)(\\w*?)).*?(?=('>))|((?<=center\">)(\\d{1,7}?)).*?(?=(</div>))");
//将 gupiao.txt的内容存入gupiao1.txt
while ((str = in.readLine()) != null){
owsout.write(str);
owsout.write("\r\n") ;
}
owsout.close();
fosout.close();//保存gupiao1.txt,关闭
//获取源文件内容 匹配 输出
while ((str = br.readLine()) != null) {
//j++;
//列名
Matcher n = q.matcher(str);
//数据
Matcher m = p.matcher(str);
//提取 列名
while (n.find()) {
//形式转换 成 String
s = String.valueOf(n.group());
//输出到文本文档
ows.write(s + " ");
System.out.printf("%-44s", n.group());
}
//提取 数据
while (m.find()) {
if (i == 0){
System.out.println();
ows.write("\r\n");
}
i++;
s = String.valueOf(m.group());
ows.write(s + " ");
System.out.printf("%-22s", m.group());
//每输出完一行 回车
if (i % 7 == 0)
{
System.out.println();
ows.write("\r\n") ;
}
}
}
//System.out.println(j);
ows.close();
fos.close();
br.close();
fr.close();
fosout.close();//关闭输出流。
功能未完善的程序部分,本来以为会比较简单,结果发现这个方法繁琐且不可行
/
File file21=new File("D:\\XiAoOMAn\\GuPiao.txt");//
File file22=new File("D:\\XiAoOMAn\\GuPiao1.txt");//
FileReader fr21=new FileReader(file21);
FileReader fr22=new FileReader(file22);
BufferedReader in21=new BufferedReader(fr21);
BufferedReader in22=new BufferedReader(fr22);
str = in21.readLine();
owsreason.write(str);
owsreason.write("\r\n") ;
in21.readLine();
in22.readLine();
in22.readLine();
str = in21.readLine();
str1 = in22.readLine();
String[] date = str.split("-");//以 - 为间隔将一行数据拆分。2009-10-15 可以拆分为 2009 10 15
String[] date1 = str1.split("-");
int []num = new int[3];
int []num1 = new int[3];
num[0]=Integer.parseInt(date[0]);//转化为整数
//num[1]=Integer.parseInt(date[1]);//
//num[2]=Integer.parseInt(date[2]);//
num1[0]=Integer.parseInt(date1[0]);//
//num1[1]=Integer.parseInt(date1[1]);//
//num1[2]=Integer.parseInt(date1[2]);//
if(num[0] > num1[0]){
owsreason.write(str);
owsreason.write("\r\n") ;
while((str = in21.readLine()) != null){
owsreason.write(str);
owsreason.write("\r\n") ;
}
owsreason.write(str1);
owsreason.write("\r\n") ;
while((str1 = in22.readLine()) != null){
owsreason.write(str1);
owsreason.write("\r\n") ;
}
}
else{
owsreason.write(str1);
owsreason.write("\r\n") ;
while((str1 = in22.readLine()) != null){
owsreason.write(str1);
owsreason.write("\r\n") ;
}
owsreason.write(str);
owsreason.write("\r\n") ;
while((str = in21.readLine()) != null){
owsreason.write(str);
owsreason.write("\r\n") ;
}
owsreason.close();
fosreason.close();
}
}
}
分享到:
相关推荐
数据更新与分页数据更新与分页数据更新与分页数据更新与分页数据更新与分页数据更新与分页数据更新与分页数据更新与分页
查询数据及更新数据.ppt查询数据及更新数据.ppt
数据更新时以为drawLine()函数在updated()里面执行(这种情况之前碰到过),后来发现热更新之后视图更新了,所以跟周期函数没有关系;参考了一下网上的一些资料,发现可以用vue中的watch()函数来监听数据的更新,...
c# 数据更新操作c# 数据更新操作vc# 数据更新操作c# 数据更新操作
1、熟练update,delete,insert语句进行更新数据库操作 2、创建视图以及操作视图的基本使用方法, ...熟悉通过SQL语句更新数据库、创建视图以及操作视图的基本使用方法,熟悉DBMS系统关于数据库完整性的约束限制。
数据更新器
本资源为数据库实验,关于数据更新的一些内容,仅供参考
ADO.NET的数据更新 ADO.NET的数据更新
数据更新 使用NAVICAT工具更新数据 课程目标 1)掌握 ——使用navicat工具进行数据插入的方法; 2)掌握 ——使用navicat工具进行数据修改的方法; 3)掌握 ——使用navicat工具进行数据删除的方法。 使用navicat...
实验3、数据更新 3.1 实验目的 熟悉数据库的数据更新操作,能够使用SQL语句对数据库进行数据的插入、更新、删除操作。 3.2 实验内容 在本实验中,主要内容是如何用SQL语句对数据进行更新。 使用INSERT INTO...
数据现势性是数据服务能力的重要指标之一,多种地理信息数据库并存与分数据库独立更新的更新方式之间的矛盾日益凸显。文中提出了一种以共有要素为核心,采用增量更新包技术,同步更新多数据库的联动更新方法。选取兰州...
以下小编给大家列出了三种实现thinkphp批量更新数据的方法,写的不好还请见谅,有意见欢迎提出,共同学习进步! 方法一: //批量修改 data二维数组 field关键字段 参考ci 批量修改函数 传参方式 function batch_...
今天我们就来介绍一下在PyQtGraph中根据实时数据更新绘制图形。 今天的例子我们通过编写一个电脑CPU实时使用率助手来讲解。 一、通过Python获取实时的CPU信息 在Windows操作系统的电脑上,我们通过“任务管理器”...
VB 利用UPDATE语句批量更新数据表中的数据 VB 利用UPDATE语句批量更新数据表中的数据
利用rowid快速在线更新海量数据 利用rowid快速在线更新海量数据
对表中数据进行更新,习题对表中数据进行更新
ListView列表数据更新,notifyDataSetChanged()方法 实现代码,简单易懂。是新手学习的好demo
更新数据透视表的数据.xlsx源码EXCEL VBA宏编程xlsx实例代码下载更新数据透视表的数据.xlsx源码EXCEL VBA宏编程xlsx实例代码下载更新数据透视表的数据.xlsx源码EXCEL VBA宏编程xlsx实例代码下载更新数据透视表的数据...
数据库实验报告数据更新.pdf
SQL数据的查询和更新实验报告报告.docx