matlab 如何删除矩阵中的NaN值?
现有矩阵part如下,111[9,1,NaN]21111[9,1,NaN]22112[9,1,1]11112[9,1,2]11213[9,2,NaN]21313[9,3,...
现有矩阵part如下,
1 11 [9,1,NaN] 2 1
1 11 [9,1,NaN] 2 2
1 12 [9,1,1] 1 1
1 12 [9,1,2] 1 1
2 13 [9,2,NaN] 2 1
3 13 [9,3,NaN] 2 1
2 13 [9,2,NaN] 2 2
3 13 [9,3,NaN] 2 2
2 14 [9,2,1] 1 1
2 14 [9,2,2] 1 1
其中第三列中有不少NaN值,希望将其删除,以免影响到length(part{i,3})的计算,请路过的网友,帮忙。多谢了。 展开
1 11 [9,1,NaN] 2 1
1 11 [9,1,NaN] 2 2
1 12 [9,1,1] 1 1
1 12 [9,1,2] 1 1
2 13 [9,2,NaN] 2 1
3 13 [9,3,NaN] 2 1
2 13 [9,2,NaN] 2 2
3 13 [9,3,NaN] 2 2
2 14 [9,2,1] 1 1
2 14 [9,2,2] 1 1
其中第三列中有不少NaN值,希望将其删除,以免影响到length(part{i,3})的计算,请路过的网友,帮忙。多谢了。 展开
3个回答
展开全部
可以通过find函数来搞定。
可以通过importdata('data.txt')将数据文件data.txt导入数组A中。
A=importdata('data.txt')
然后通过命令
z=find(~isnan(A))
将A数组中NaN所在的编号给找出来;
B=A(z)
就可以将A中所有的NaN值剔除掉了,如果希望得到非NaN值的编号,那么z就是了!
如果只求将A中NaN值去掉,那么B=A(~isnan(A))就可以搞定!
当然,此方法也可以将数组中某个数替换或者剔除。
比如我们有个数组
A=[1,2;0,3]
希望将数组A中的0给找出并剔除掉。
z=find(A==0);
A(z)=[];
可以通过importdata('data.txt')将数据文件data.txt导入数组A中。
A=importdata('data.txt')
然后通过命令
z=find(~isnan(A))
将A数组中NaN所在的编号给找出来;
B=A(z)
就可以将A中所有的NaN值剔除掉了,如果希望得到非NaN值的编号,那么z就是了!
如果只求将A中NaN值去掉,那么B=A(~isnan(A))就可以搞定!
当然,此方法也可以将数组中某个数替换或者剔除。
比如我们有个数组
A=[1,2;0,3]
希望将数组A中的0给找出并剔除掉。
z=find(A==0);
A(z)=[];
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你的数据,应该是length(part{i,3})的结果全部是3
你是要把part{i,3}内有NaN的数去掉,然后length(part{i,3})的结果变为非NaN的数的个数吗?
如果是,可以这样
for ii = 1:size(part, 1)
temp = part{i, 3};
part{i, 3} = temp(~isnan(temp));
end
你是要把part{i,3}内有NaN的数去掉,然后length(part{i,3})的结果变为非NaN的数的个数吗?
如果是,可以这样
for ii = 1:size(part, 1)
temp = part{i, 3};
part{i, 3} = temp(~isnan(temp));
end
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
A=A(1-find(A==NaN));
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询