find ( strcmp ( many_different_elements )
    7 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
Hello, I want to check if any of the elements of a cell CC with 90 elements are in column2 of a matrix w 10k rows. If so, to retrieve the row location.
CC below has four elements
CC={'AB1', 'AB2', 'AB3' ,'AB4'}
I would use
idloc = find(strcmp(databig{:,2}, 'AB1') | strcmp(databig{:,2}, 'AB2')  | strcmp(databig{:,2}, 'AB3')   | strcmp(databig{:,2}, 'AB4') )
But was wondering if there's a nicer way than to write 90 times in the find line
2 comentarios
  Mitchell Thurston
      
 el 14 de Oct. de 2021
				I'm not too experienced with strcmp so there might be a better way, but the easiest way I can think of for this would be
per_index = zeros(numel(CC),1);
for i = 1:length(per_index)
    per_index(i) = any( strcmp(databig{:,2}, CC{i}) );
end
idloc = any(per_index)
I would also recommend using "any" for each strcmp instead of find
  Mitchell Thurston
      
 el 14 de Oct. de 2021
				I just noticed the end of the first sentence also wanted the row location. The general idea should still work.
Respuestas (2)
  Ryan
      
 el 14 de Oct. de 2021
        You could create a for loop that checks each element and then do the find outside the four loop for find the rows. Something like this
CC = {'AB1', 'AB2', 'AB3' ,'AB4'};
for ii = 1:length(CC)
    idx(:,ii) = strcmp(databig,CC{ii});
end
[idloc,~] = find(idloc);
0 comentarios
  Stephen23
      
      
 el 14 de Oct. de 2021
        
      Editada: Stephen23
      
      
 el 14 de Oct. de 2021
  
      "But was wondering if there's a nicer way than to write 90 times in the find line"
Of course: forget about repeated STRCMP calls (e.g. in a loop), just use one ISMEMBER call:
Read its documentation and pay careful attention to the order of its inputs and outputs.
X = ismember(databig(:,2),CC)
0 comentarios
Ver también
Categorías
				Más información sobre Loops and Conditional Statements en Help Center y File Exchange.
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!



