Azzera filtri
Azzera filtri

Finding values of specific range from table row or column

3 visualizzazioni (ultimi 30 giorni)
Hi,
I'm having the Table whose first column is as A = [12345 NaN NaN NaN NaN 457 NaN NaN NaN 785 NaN NaN NaN NaN NaN NaN 74502]
I want to select range as 12345 to NaN (shown in bold) , 457 to NaN and so on.
Please guide.

Risposta accettata

Stephen23
Stephen23 il 26 Lug 2019
Modificato: Stephen23 il 26 Lug 2019
>> A = [12345 NaN NaN NaN NaN 457 NaN NaN NaN 785 NaN NaN NaN NaN NaN NaN 74502].'
A =
12345
NaN
NaN
NaN
NaN
457
NaN
NaN
NaN
785
NaN
NaN
NaN
NaN
NaN
NaN
74502
Method one: accumarray:
>> C = accumarray(cumsum(~isnan(A)),A,[],@(v){v});
>> C{:}
ans =
12345
NaN
NaN
NaN
NaN
ans =
457
NaN
NaN
NaN
ans =
785
NaN
NaN
NaN
NaN
NaN
NaN
ans =
74502
Method two: mat2cell:
>> X = diff(find([true;diff(isnan(A))<0;true]));
>> C = mat2cell(A,X,1);
>> C{:}
ans =
12345
NaN
NaN
NaN
NaN
ans =
457
NaN
NaN
NaN
ans =
785
NaN
NaN
NaN
NaN
NaN
NaN
ans =
74502

Più risposte (1)

Shreya Shetty
Shreya Shetty il 26 Lug 2019
Modificato: madhan ravi il 26 Lug 2019
  1 Commento
madhan ravi
madhan ravi il 26 Lug 2019
Modificato: madhan ravi il 26 Lug 2019
No, indices should be determined by the code and not by giving it manually.

Accedi per commentare.

Categorie

Scopri di più su Tables in Help Center e File Exchange

Tag

Prodotti


Release

R2017b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by