error using unique function

s is a cell matrix (178000x9) I want to find the unique values of s in the first column. ID=unique(s(:,1));
I received the following error. Error using cell/unique (line 95) Input A must be a cell array of string
what could be the reason?

1 Comment

If the first column is all non-numeric it would not be throwing that error. What is returned from:
iscellstr(s(:,1))

Sign in to comment.

 Accepted Answer

Mike Hosea
Mike Hosea on 26 Jul 2012
Edited: Mike Hosea on 26 Jul 2012
What type of data is in the cell array? When you use UNIQUE on a cell array, the only case that's supported is when the elements of the cell array are strings. Is that case not working for you?
>> c = {'abc','abc','def','defg'}';
>> unique(c(:,1))
ans =
'abc'
'def'
'defg'

7 Comments

no . I am receiving an error Error using cell/unique (line 95) Input A must be a cell array of string
Do you have [] entries? Make sure that any empty entries are '', not [].
how can I tell if I have []. visually I can't because it take too long to load and I have too many observations
You can use iscellstr as I did above.
iscellstr(s(:,1))
ans =
0
Yes, this is what we expected. You do not have a cell array of only strings. You can find the non-strings with
find(cellfun(@(x)~ischar(x),s))
You do not mention where this data came from. If it began as a
s = cell(m,n);
and was later partially populated, then you might resolve the problem by changing that to
s = repmat({''},m,n);
Thanks this solved the problem

Sign in to comment.

More Answers (1)

Wayne King
Wayne King on 26 Jul 2012
Edited: Wayne King on 26 Jul 2012
Is it a cell array of numeric values?
You can use cell2mat()
A = {1 5 9 ; 2 3 4; 2 4 5};
B = unique(cell2mat(A(:,1)));

1 Comment

column 1 contains names . it is non-numeric

Sign in to comment.

Categories

Tags

Community Treasure Hunt

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

Start Hunting!