How to use find function to find input of 'cell' type?

3 Ansichten (letzte 30 Tage)
C Zeng
C Zeng am 15 Apr. 2015
Bearbeitet: Image Analyst am 16 Apr. 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 Kommentare
Image Analyst
Image Analyst am 15 Apr. 2015
No it's not. But see if my answer below is okay.

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

Image Analyst
Image Analyst am 15 Apr. 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 Kommentare
C Zeng
C Zeng am 15 Apr. 2015
Bearbeitet: C Zeng am 15 Apr. 2015
What if I want to find out which row return number j (j changes in the loop), where the column vector is of cells.
if I input: ismember(list, 'j'); it returns an error: Input A of class cell and input B of class cell must be cell arrays of strings, unless one is a string.
Thanks!
Image Analyst
Image Analyst am 16 Apr. 2015
Bearbeitet: Image Analyst am 16 Apr. 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.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Data Type Conversion finden Sie in Help Center und File Exchange

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by