find a row in a multidimensional cell array
Afficher commentaires plus anciens
Hi, I have a cell variable as follows, temp =
'FBgn0039563' 'FBgn0259937' [0.6195]
'FBgn0039563' 'FBgn0024733' [0.5698]
'FBgn0039563' 'FBgn0011236' [0.5247]
'FBgn0039563' 'FBgn0053864' [0.5155]
'FBgn0039563' 'FBgn0035951' [0.5781]
'FBgn0039563' 'FBgn0001224' [0.5462]
'FBgn0039563' 'FBgn0002914' [0.5162]
'FBgn0039563' 'FBgn0264492' [0.8405]
'FBgn0039563' 'FBgn0000259' [0.7570]
'FBgn0039563' 'FBgn0004103' [0.5374]
I want to search a key =['FBgn0039563' 'FBgn0264492' [0.8405]] inside temp. I need the row index of key in temp. Is it possible?
Thanks in advance,
Best Regards, Wasim
1 commentaire
Wasim Aftab
le 26 Sep 2017
Modifié(e) : Wasim Aftab
le 26 Sep 2017
Réponse acceptée
Plus de réponses (2)
Jan
le 4 Juil 2017
Search = {'FBgn0039563' 'FBgn0264492' [0.8405]}
Match = strcmp(temp(:, 1), Search{1}) & ...
strcmp(temp(:, 2), Search{2}) & ...
cat(1, temp{:, 3}) == Search{3};
Index = find(Match);
3 commentaires
Wasim Aftab
le 5 Juil 2017
Jan
le 5 Juil 2017
@Wasim Aftab: And therefore it would be useful, if you explain the needs exactly. In your original question the key was a single row only.
Then:
Match = ismember(temp(:, 1), Search(1, :)) & ...
ismember(temp(:, 2), Search(2, :)) & ...
ismember(cat(1, temp{:, 3}), cat(1, Search{3, :}));
Wasim Aftab
le 7 Juil 2017
Andrei Bobrov
le 4 Juil 2017
find(all(ismember(temp(:,1:2),key(1:2)),2) & ismember([temp{:,3}]',key{3}))
7 commentaires
Wasim Aftab
le 5 Juil 2017
Andrei Bobrov
le 5 Juil 2017
Modifié(e) : Andrei Bobrov
le 5 Juil 2017
:)
find(all(ismember(temp(:,1:2),key(:,1:2)),2) & ismember([temp{:,3}]',[key{:,3}]))
Wasim Aftab
le 7 Juil 2017
Andrei Bobrov
le 7 Juil 2017
Thank you Wasim!
Wasim Aftab
le 26 Sep 2017
Andrei Bobrov
le 26 Sep 2017
[l,ii] = ismember(temp,key,'rows');
Wasim Aftab
le 2 Fév 2018
Modifié(e) : Wasim Aftab
le 2 Fév 2018
Catégories
En savoir plus sur Creating and Concatenating Matrices dans Centre d'aide et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!