|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
matlab读取网络数据的能力和python相比太弱了,python有很多开源工具包,功能非常强大。其实以前批量下载数据都是用python语言写的,但是现在因为工作需要每天都要用matlab,所以尝试用matlab写个小程序批量下载网络数据。要下载的数据网址是:
- ]$ n' z, \0 e9 U2 l6 q
z% ^% i( M A0 u8 w5 yhttp://www.esrl.noaa.gov/psd/thredds/catalog/Datasets/godas/catalog.html; x! N( \$ t5 ] P9 |+ T! a. v
' r$ g9 }2 S- g) ^- C
要下载的数据如下:pottmp.1980.nc到pottmp.2016.nc,共37个nc文件
+ _8 m/ h3 r# k0 H2 E
% h6 `! l8 a5 z7 Q4 l; F程序如下,核心函数是urlwrite
6 }( z& K! Q9 H8 Z3 W7 a; Q; g% f ~6 D5 {3 K- ~4 \' D5 B
filepath='D:用户目录Desktoppottmp';: n3 I3 [( F) j( U# A. A @
mkdir(filepath); %在桌面创建文件夹pottmp+ r( ~/ c+ o0 h/ H/ [# q H3 p) Y
! B. W0 B9 f0 ?+ Z1 m% ^9 _
for i=1980:2016
# q- f7 u9 l1 h0 J( X' QfullURL=['http://www.esrl.noaa.gov/psd/thredds/fileServer/Datasets/godas/pottmp.',num2str(i),'.nc'];%下载网址' k8 a) n1 Z, C1 K- s3 u
filename=[filepath,'pottmp.',num2str(i),'.nc']; %保存的文件名
1 J8 k* A8 e' m* R( m5 u t/ H8 d9 itic;. c! ~) @7 x! D! j' L/ H/ V
[f,status]=urlwrite(fullURL,filename);%下载命令
) n$ X3 o: J: J/ ^3 B" B. Dif status==1
& n# H1 e% E5 J m" n t=toc;
6 D; Y2 K7 d8 [7 V! c lst=dir(filename);$ O6 f# a3 G1 X! G
xi=lst.bytes;% D# w8 }8 i5 n, t
disp(['pottmp.',num2str(i),'.nc','下载成功','文件大小为',num2str(xi/1024/1024),'M',' 花费',num2str(t/60),'分钟']);1 i& F) v2 c. N8 E0 \2 ?
else
+ B+ T1 u' B& i- ^6 m8 B0 A disp(['pottmp.',num2str(i),'.nc','下载失败']);& T) f+ ?# z( |# R- L; q& J2 A
end5 M: N( R, c4 F' i e
end
p# n; {& M, R. ~. }8 Z I7 Y
- Z& n1 y! K j |
|