|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
一、R2008b中nc常用命令
0 ?) `6 D/ E: N9 P: D我以R2008b为例,下载上述地址的nc工具箱加载到路径下(详细的到网上搜,有很多详细的过程),在这里只介绍最常用的命令给新手。
# U% V+ y* k: j/ k/ ~7 _/ ~1.ncdump filename4 L8 \' a- }8 Q% i- `8 K
filename是你的文件名,注意如果不是当前路径请写绝对路径,后缀名要有.nc。
* T% p7 n; r4 N: L这个命令是用来查看nc文件的信息。具体的你可以下载个sst的nc文件读读看就知道了。一般我们需要从中了解经度、纬度它们的范围和网格点数,还有时间,最后就是变量。变量一般需要知道它的单位,缺测值(missing value),scale factor。因为这些影响你最后的出图。缺测值需要设置成NaN,Matlab对非数不作处理。乘上scale才是正确的数值,避免出现出图的数值多了10倍或少了10倍的情况。/ m2 ^9 U- S3 E8 L/ }1 x& r
2.ncload filename4 `$ F, S$ A( q& L6 v
这个命令是用于载入所有变量到workspace中。载入后就可以对数据进行处理和绘图了。这里需要注意的是,通常要对陆地设为NaN,所以要通过ncdump知道缺测值的数,用于改成NaN,Matlab不作处理。还有就是需要你对scale做处理成真实的数值。这里面介绍简便的方法对NaN和scale做处理(如果你没ncdump的话); N C! y9 u) i' d
载入数据后输入:
# ^& y& a1 a- U' ^global nctbx_options;: j# ^, z* |' T- t: m
nctbx_options.theAutoNaN = 1;3 w7 x% T- i. S8 P: d
nctbx_options.theAutoscale = 1;
1 i; a. k& W* v$ l8 E- A# h这三行命令就可以很方便的设置NaN和scale了。: z0 l0 x6 `! ] S. N2 \* `
具体的在你R2008b中help netcdf可查看所有命令使用方法。1 U3 W- z: p+ H( v. {0 T' \1 T+ t
R2008b常用命令就介绍到这。其它的help~
' `% G; @* G; m" I; I/ m+ n: C$ `7 P. _4 b- w$ r* V1 o/ |
二、R2012a中nc常用命令6 E5 X Y _' H
高版本的Matlab自带nc工具箱。2012以上的版本肯定都自带了。所以不用再下载工具箱了,直接用它里面的函数。但对于用惯以前nc命令的人来说又要重新学习新的nc命令,所以在这里我把最常用的命令列出来,能解决绝大多数问题。
! W+ D- X+ k$ ~$ M k- O: r, n1. ncdisp filename(Display contents of NetCDF data source in Command Window)5 E% |0 \7 K$ _9 y4 m$ P
如果你就想查看nc文件的信息,想和ncdump一样。在2012a中用ncdisp命令就能查看了。用法和ncdump一样。具体其他用法查看help或者doc ncdisp./ h' v/ a+ S$ ~7 f
2. ncread(Read data from variable in NetCDF data source)
% s4 A. k1 F0 y3 i0 S4 asyntax:4 Y8 p) p2 V4 i0 g" Y k
vardata = ncread(source,varname)! j' o% \' R- R
vardata = ncread(source,varname,start,count,stride)
- ?7 Q* f I, m W& [4 P直接解释第二条语法:! j2 ^! U+ v! {5 y7 M
vardata是你自己想设的变量名;source是你的nc文件(字符型);varname是你想载入的变量名(字符型);start是你这个变量想从哪开始,如[1 1]表示二维变量从最开始读;count表示读入变量的数量,如[50 50]表示读入第一维50个数,第二维50个数;stride意思就是步长,默认的是1,但你也可以设置跳着读数据,如[2 2]表示每间隔两个数读数据。
5 X- h8 w3 Q5 N" j
E; }% T: Q" h2 `# K7 I如何找到我们想要从哪个经纬度读数据呢?我们可以把lon和lat载入到工作空间后结合find函数使用。6 y7 @6 z3 U% L
比如:我们想要读取经度是120~290度,纬度是-30~30度的数据。可参考如下程序:9 M7 I$ t w9 i+ v6 A, U
lon=ncread(...,'lon');% Y* r5 R0 X; k- y% u8 y2 x1 n2 {
lat=ncread(...,'lat');1 g$ V2 A. s( z
a=find(lon>=120 & lon<=290);! P* U$ B2 C) K+ e; v* s
b=find(lat>=-30 & lat<=30); % a和b作为经度和纬度的指针1 M$ I% I! l! D+ b3 z0 p
lon_num=length(a);
; o7 P0 Y( N" O3 z- ulat_num=length(b);: r5 q, g3 r1 y% a) f
sst=ncread(...,'sst',[a(1) b(1) ...],[lon_num lat_num ...]); % 假如是读取SST数据- [' |# ~/ q0 U: |' m, [
" J/ u. c p" s b% Q5 m6 R
基本就介绍完了。
) T" ^3 c& r* [" a* yncread看似比ncload麻烦,但是如果你有大量的数据都在一个nc文件中,直接ncload会把所有的variable都读进来,但是有时我们并不想要所有的变量,而且这样读进来的速度会很慢,大大消耗资源。当然R2008b也有相应函数能实现2012a上面的功能,这就需要我们自己看help了。- g% a8 T8 E5 d4 \" e3 K% C& h
|
|