find a row in a multidimensional cell array
Mostrar comentarios más antiguos
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 comentario
Wasim Aftab
el 26 de Sept. de 2017
Editada: Wasim Aftab
el 26 de Sept. de 2017
Respuesta aceptada
Más respuestas (2)
Jan
el 4 de Jul. de 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 comentarios
Wasim Aftab
el 5 de Jul. de 2017
Jan
el 5 de Jul. de 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
el 7 de Jul. de 2017
Andrei Bobrov
el 4 de Jul. de 2017
find(all(ismember(temp(:,1:2),key(1:2)),2) & ismember([temp{:,3}]',key{3}))
7 comentarios
Wasim Aftab
el 5 de Jul. de 2017
Andrei Bobrov
el 5 de Jul. de 2017
Editada: Andrei Bobrov
el 5 de Jul. de 2017
:)
find(all(ismember(temp(:,1:2),key(:,1:2)),2) & ismember([temp{:,3}]',[key{:,3}]))
Wasim Aftab
el 7 de Jul. de 2017
Andrei Bobrov
el 7 de Jul. de 2017
Thank you Wasim!
Wasim Aftab
el 26 de Sept. de 2017
Andrei Bobrov
el 26 de Sept. de 2017
[l,ii] = ismember(temp,key,'rows');
Wasim Aftab
el 2 de Feb. de 2018
Editada: Wasim Aftab
el 2 de Feb. de 2018
Categorías
Más información sobre Creating and Concatenating Matrices en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!