find a row in a multidimensional cell array
Show older comments
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 Comment
Wasim Aftab
on 26 Sep 2017
Edited: Wasim Aftab
on 26 Sep 2017
Accepted Answer
More Answers (2)
Jan
on 4 Jul 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 Comments
Wasim Aftab
on 5 Jul 2017
Jan
on 5 Jul 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
on 7 Jul 2017
Andrei Bobrov
on 4 Jul 2017
find(all(ismember(temp(:,1:2),key(1:2)),2) & ismember([temp{:,3}]',key{3}))
7 Comments
Wasim Aftab
on 5 Jul 2017
Andrei Bobrov
on 5 Jul 2017
Edited: Andrei Bobrov
on 5 Jul 2017
:)
find(all(ismember(temp(:,1:2),key(:,1:2)),2) & ismember([temp{:,3}]',[key{:,3}]))
Wasim Aftab
on 7 Jul 2017
Andrei Bobrov
on 7 Jul 2017
Thank you Wasim!
Wasim Aftab
on 26 Sep 2017
Andrei Bobrov
on 26 Sep 2017
[l,ii] = ismember(temp,key,'rows');
Wasim Aftab
on 2 Feb 2018
Edited: Wasim Aftab
on 2 Feb 2018
Categories
Find more on Creating and Concatenating Matrices in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!