Réponses:
Je suppose que le code suivant pourrait faire l'affaire:
strs = {'HA' 'KU' 'LA' 'MA' 'TATA'}
ind=find(ismember(strs,'KU'))
Cela renvoie
ans =
2
>> strs = {'HA' 'KU' 'LA' 'MA' 'TATA'};
>> tic; ind=find(ismember(strs,'KU')); toc
Le temps écoulé est de 0,001976 secondes.
>> tic; find(strcmp('KU', strs)); toc
Le temps écoulé est de 0,000014 seconde.
SO, strcmp('KU', strs)
prend clairement beaucoup moins de temps queismember(strs,'KU')
Depuis 2011a, la méthode recommandée est:
booleanIndex = strcmp('KU', strs)
Si vous souhaitez obtenir l'index entier (dont vous n'avez souvent pas besoin), vous pouvez utiliser:
integerIndex = find(booleanIndex);
strfind
est obsolète, alors essayez de ne pas l'utiliser.
Je vois que tout le monde a manqué la faille la plus importante de votre code:
strs = {'HA' 'KU' 'LA' 'MA' 'TATA'}
devrait être:
strs = {'HA' 'KU' 'NA' 'MA' 'TATA'}
ou
strs = {'HAKUNA' 'MATATA'}
Maintenant, si vous vous en tenez à utiliser
ind=find(ismember(strs,'KU'))
Vous n'aurez aucun souci :).
D'autres réponses sont probablement plus simples pour ce cas, mais pour être complet, j'ai pensé ajouter l'utilisation de cellfun avec une fonction anonyme
indices = find(cellfun(@(x) strcmp(x,'KU'), strs))
ce qui a l'avantage de pouvoir facilement le rendre insensible à la casse ou de l'utiliser dans les cas où vous avez un tableau de cellules de structures:
indices = find(cellfun(@(x) strcmpi(x.stringfield,'KU'), strs))
Code le plus court:
strs = {'HA' 'KU' 'LA' 'MA' 'TATA'};
[~,ind]=ismember('KU', strs)
Mais il ne renvoie que la première position dans strs
. Si l'élément n'est pas trouvé, alors ind=0
.
Les fonctions strcmp et strcmpi sont le moyen le plus direct de le faire. Ils recherchent dans les tableaux.
strs = {'HA' 'KU' 'LA' 'MA' 'TATA'}
ix = find(strcmp(strs, 'KU'))
as-tu essayé
indices = Find(strs, 'KU')
voir le lien
alternativement,
indices = strfind(strs, 'KU');
devrait également fonctionner si je ne me trompe pas.