matlab 抓取新浪,[转载]如何利用Matlab抓取网页数据

%朋友需要做金融方面的分析,要求从网站上下载大量的数据,一个一个复制粘贴太费事。我写了一个简单的网络爬虫,主要用到正则表达式,可以自动下载网页源文件里面的数据。

clc;

clear;

warning off;

for year =

2010:2011 %年份

for season =

1:4 %季度

fprintf('%d年%d季度的数据...', year, season)

[sourcefile, status] =

urlread(sprintf('http://vip.stock.finance.sina.com.cn/corp/go.php/vMS_MarketHistory/stockid/000001/type/S.phtml?year=%d&season=%d',

year));

if ~status

error('读取出错!n')

end

expr1 =

's+(dddd-dd-dd)s*'; %获取日期('s'空格字符间的日期数据)

[datefile, date_tokens]= regexp(sourcefile, expr1, 'match',

'tokens'); %返回正则表达式的两个关键字

'match'和 'tokens'

date = cell(size(date_tokens));

for idx = 1:length(date_tokens)

date{idx} =

date_tokens{idx}{1}; %length(date_tokens)行 1列

end

expr2 = '

align="center">(d*.?d*)

';

%从源文件中获取目标数据

[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}); %length(data_tokens)行 1列

end

data = reshape(data, 6, length(data)/6 )'; %重排

数据表格形式为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季度',

season); %工作表名称

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')

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值