MATLAB Answers

Delete rows with NaN for a cell array

161 views (last 30 days)
Rooy
Rooy on 26 Jun 2013
I want to remove the rows that have NaN and still keep the dimension of the array intact.
[ NaN] [ NaN] [ NaN] [ NaN]
[ NaN] [ NaN] [ NaN] [ NaN]
'Total RADIO Drops' 'Total Drops' 'CC DCR (%)' 'RADIO DCR (%)'
Above is just an example, I have over a thousand rows.
The only problem I have now is removing rows which have NaN and string together
Thank you

  1 Comment

Rooy
Rooy on 26 Jun 2013
Is there a way to delete the rows which have strings and Nan mixed together ?
[ 'A'] [ NaN] [ NaN] [ NaN]
'Total RADIO Drops' 'Total Drops' 'CC DCR (%)' 'RADIO DCR (%)'

Sign in to comment.

Accepted Answer

Tom
Tom on 26 Jun 2013
A(any(cellfun(@(x) any(isnan(x)),A),2),:) = [];

  1 Comment

Sign in to comment.

More Answers (1)

Andrei Bobrov
Andrei Bobrov on 26 Jun 2013
Edited: Andrei Bobrov on 26 Jun 2013
A - your cell array
out = A(any(cellfun(@(x)any(~isnan(x)),A),2),:);
ADD
out = A(all(cellfun(@(x)any(~isnan(x)),A),2),:);

  3 Comments

Rooy
Rooy on 26 Jun 2013
That works thank you, is there a way to delete the rows which have strings and Nan mixed together ?
Rooy
Rooy on 26 Jun 2013
Thank you for your great help

Sign in to comment.


Translated by