How to use find function to find input of 'cell' type?
3 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
C Zeng
le 15 Avr 2015
Modifié(e) : Image Analyst
le 16 Avr 2015
Hello, I have 'raw' as an array of all cells read from excel (number or non-number). I would like to find the row numbers where the cell is 'ABC', and return the first row.
When I use 'find' function it returns an error:
>>find(raw, 'ABC','first')
Undefined function 'find' for input arguments of type 'cell'.
Is there a way to find the row for a cell content in Matlab? If so, how can I find the row of both that one vector having some cell, and another vector having another cell?
4 commentaires
Réponse acceptée
Image Analyst
le 15 Avr 2015
ca = {'abc', 'def';
'abcx', 'row 2';
'yy', 'row 2 abc';
'zzzz', 'abc';
'abc', 'line 3'}
[ia, ib] = ismember(ca, 'abc')
firstRow = find(ia(:, 1), 1, 'first')
In the command window:
ca =
'abc' 'def'
'abcx' 'row 2'
'yy' 'row 2 abc'
'zzzz' 'abc'
'abc' 'line 3'
ia =
1 0
0 0
0 0
0 1
1 0
ib =
1 0
0 0
0 0
0 1
1 0
firstRow =
1
2 commentaires
Image Analyst
le 16 Avr 2015
Modifié(e) : Image Analyst
le 16 Avr 2015
Please create a cell array like I did so I can work on it. And tell me which row and column you want to find/detect and return to your program.
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Data Type Conversion dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!