先复制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();
}
}
}
分享到:
相关推荐
在当今信息高速发展的时代,数据更新已成为日常工作中不可或缺的一部分。尤其在IT行业,无论是数据库管理、数据分析还是确保应用系统稳定运行,都对数据的时效性和准确性有着极高的要求。针对这些需求,"mxy数据更新...
查询数据及更新数据.ppt查询数据及更新数据.ppt
数据更新时以为drawLine()函数在updated()里面执行(这种情况之前碰到过),后来发现热更新之后视图更新了,所以跟周期函数没有关系;参考了一下网上的一些资料,发现可以用vue中的watch()函数来监听数据的更新,...
1. 数据更新未触发视图刷新的原因: - 数据绑定错误:确保你使用的是Vue的响应式属性(`data`、`props`、`computed`等)进行数据绑定,而非直接修改`this`上下文中的变量。 - 异步操作:Vue不会监听异步操作中对...
在Qt框架中,模型/视图(Model/View)架构是一种设计模式,它将数据处理与用户界面分离开来,使得数据的管理更加灵活,同时能够实现数据的实时更新。这个设计模式是基于MVC(Model-View-Controller)概念的,其中...
在VB(Visual Basic)编程环境中,我们经常需要与数据库进行交互,这包括读取、插入、更新和删除数据。在本教程中,我们将专注于“利用UPDATE语句批量更新数据表中的数据”这一主题。UPDATE语句是SQL语言的一个重要...
今天我们就来介绍一下在PyQtGraph中根据实时数据更新绘制图形。 今天的例子我们通过编写一个电脑CPU实时使用率助手来讲解。 一、通过Python获取实时的CPU信息 在Windows操作系统的电脑上,我们通过“任务管理器”...
本教程将深入探讨在C#中,当DataGridView与数据源绑定后如何进行数据的增加、删除、插入和更新操作。 ### 数据源绑定 首先,我们需要创建一个数据源,这可以是任何实现了`IList`或`IBindingList`接口的对象,如...
本主题聚焦于如何利用VBA更新双色球数据源,这对于彩票数据分析或者爱好者来说是非常实用的。下面我们将深入探讨这个主题。 首先,VBA代码通常在Excel的宏(Macros)中编写。在“开发工具”菜单下,你可以找到宏...
总结,`ExpandableListView`是Android中处理层次结构数据的强大工具,通过正确地操作数据模型、适配器和UI更新,可以构建出功能丰富的交互式列表。在实际应用中,要注意性能优化和用户交互的设计,以提供更好的用户...
在提供的文件"ListViewRefresh"中,可能包含了实现上述功能的相关代码示例,包括自定义Adapter的实现、数据更新的逻辑以及可能的优化技巧。建议结合代码深入学习,以便更好地理解和掌握ListView数据更新的实践操作。
使用PLSQL语句对表中数据进行更新,对表中数据进行更新
双色球开奖,数据可自动更新,利用excel vba bianxie
在本文中,我们将深入探讨如何使用C++和Qt框架中的QChart组件来创建一个动态图表,其中的时间轴(X轴)能够随着数据的实时更新而自动调整。这个过程主要涉及Qt 5.8版本,以及Visual Studio 2013作为开发环境。我们将...
在这里,我们可以看到用于触发数据更新和清空图表的按钮,以及可能的图表显示区域。 总结一下,实现自定义封装的Qt柱状图类主要涉及以下步骤: 1. **创建柱状图类**:继承`QObject`,利用`QBarSeries`构建柱状图。...
kettle数据抽取、数据清洗、数据装换, 作业根据时间戳更新插入数据完整demo 1、先获取时间戳 2、删除目标库大于时间戳的 3、数据同步,获取源表跟目标表大于时间戳的,比较, 目标表多的删除, 少的插入更新 4...
数据库数据更新是数据库管理的核心环节,它不仅影响数据的准确性与一致性,还与数据库的性能紧密相关。更新策略的制定需要考虑到变更管理、数据验证、备份与恢复、并发控制和性能优化等多个维度。 变更管理是记录和...
可以对excel内插入数据 填写要插入数据的行号 就可以用了 简单方便
【RecyclerView】 十、RecyclerView 数据更新 ( 增加单条数据 | 批量增加数据 ) https://hanshuliang.blog.csdn.net/article/details/113406856 博客源码快照