虽然如果您的文本文件中没有任何零值,Divakar的答案仍然有效,但通常情况并非如此.例如,如果您的文本数组是
1 2 3
4 0
5 6 0 7 8
然后Divakar的结果将是:
1 2 3 nan nan
4 nan nan nan nan
5 6 nan 7 8
而你真的想要:
1 2 3 nan nan
4 0 nan nan nan
5 6 0 7 8
实现这一点的最简单方法是打开dlmread函数(只需在文本编辑器中键入dlmread并按Ctrl D打开它).确保将此文件另存为您正在使用的目录中的单独文件,但名称不同(即dlmread_nan.m).
转到代码的这一部分(我的版本中的第126行):
if isempty(delimiter)
result = textscan(fid,'',nrows,'headerlines',r,'headercolumns',c,...
'returnonerror',0,'emptyvalue',0, 'CollectOutput', true);
else
delimiter = sprintf(delimiter);
whitespace = setdiff(sprintf(' \b\t'),delimiter);
result = textscan(fid,'',nrows,...
'delimiter',delimiter,'whitespace',whitespace, ...
'headerlines',r,'headercolumns',c,...
'returnonerror',0,'emptyvalue',0,'CollectOutput', true);
end
并在两种情况下将’emptyvalue’之后的值更改为NaN而不是0.保存文件.它应该如下所示:
if isempty(delimiter)
result = textscan(fid,'',nrows,'headerlines',r,'headercolumns',c,...
'returnonerror',0,'emptyvalue',NaN, 'CollectOutput', true);
else
delimiter = sprintf(delimiter);
whitespace = setdiff(sprintf(' \b\t'),delimiter);
result = textscan(fid,'',nrows,...
'delimiter',delimiter,'whitespace',whitespace, ...
'headerlines',r,'headercolumns',c,...
'returnonerror',0,'emptyvalue',NaN,'CollectOutput', true);
end
要获取数组,请使用:
result = dlmread_nan('text.txt', ' ');
%%//This will give you exactly what you're looking for.
这有点麻烦,但是通过从MATLAB的库中复制,它可能比从头开始自己编写它更加健壮和无错误.