Matlab爬虫程序

% 本程序用于获取网站中的表格


% written by longwen36
% all rights reserved 


clc,clear;


warning off;


for year = 1991:1992 %年份
    for jidu = 1:4
        
        fprintf('%d年%d季度的数据...', year, jidu)
        [sourcefile, status] = urlread(sprintf('http://vip.stock.finance.sina.com.cn/corp/go.php/vMS_MarketHistory/stockid/000001/type/S.phtml?year=%d&jidu=%d', year,jidu));
        
        if ~status
            error('读取出错!\n')
        end
        
        expr1 = '\s+(\d\d\d\d-\d\d-\d\d)\s*'; %获取日期
        [datefile, date_tokens]= regexp(sourcefile, expr1, 'match', 'tokens');
        
        
        date = cell(size(date_tokens));
        
        for idx = 1:length(date_tokens)
            date{idx} = date_tokens{idx}{1};
        end
          
        expr2 = '<div align="center">(\d*\.?\d*)</div>'; %获取数据
        
        [datafile, data_tokens] = regexp(sourcefile, expr2, 'match', 'tokens');
        
        data = zeros(size(data_tokens));
        
        for idx = 1:length(data_tokens)
            data(idx) = str2double(data_tokens{idx}{1});
        end
        
        data = reshape(data, 6, length(data)/6 )'; %重排
        
        filename = sprintf('%d年',year);
        pathname = [pwd '\data'];
        
        if ~exist(pathname,'dir')
            mkdir(pathname);
        end
        
        fullfilepath = [pwd '\data\' filename];
        % 保存数据到Excel
        sheet = sprintf('第%d季度', jidu);
        xlswrite(fullfilepath, date' , sheet);
        range = sprintf('B1:%s%d',char(double('B')+size(data,2)-1), size(data,1));
        xlswrite(fullfilepath, data, sheet, range);
        fprintf('OK!\n')
        
    end
end


fprintf('全部完成!\n')

来源:http://blog.csdn.net/rs_network/article/details/8302020
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值