extracting first letter from the cell
이전 댓글 표시
hello,
I have two cell arrays: nam1 = {'John', 'Adam', 'Emma'} nam2 = {'Doe', 'Willson', 'Brown'}
I want to create one array with initials, like this: init = {'JD', 'AW', EB'}
I tried extracting first letters from each array like this:
if true
% code
end
ininam1 = cellfun (@(x) x(1),nam1,'un',0)
ininam2 = cellfun (@(x) x(1),nam2,'un',0)
but this already fails (Index exceeds array bounds). Can you help me with this? Also combining these two arrays together?
Thanks in advance!
K.
댓글 수: 2
Stephen23
2018년 10월 15일
It worked fine when I tried it:
>> nam1 = {'John', 'Adam', 'Emma'};
>> nam2 = {'Doe', 'Willson', 'Brown'};
>> ininam1 = cellfun (@(x) x(1),nam1,'un',0)
ininam1 = 'J' 'A' 'E'
>> ininam2 = cellfun (@(x) x(1),nam2,'un',0)
ininam2 = 'D' 'W' 'B'
Kyle Pastor
2020년 4월 9일
편집: Kyle Pastor
2020년 4월 9일
I had the same issue. Turns out one of the elements of my cell arrays was an empty string.
A = {'Works','OK_DOKIE',''};
element 3 will cause the fail!
-K
채택된 답변
추가 답변 (1개)
Adam
2018년 10월 15일
res = cellfun( @(x,y) [x(1) y(1)], nam1, nam2, 'UniformOutput', false' )
works fine for me on your example, but then so does your own code. Do you have an actual example where it leads to an error?
댓글 수: 3
KDRA
2018년 10월 15일
Well, the problem certainly appears to be with your inputs, but I don't know from that exactly what the inputs look like. The example you gave works fine and I would imagine any pair of cell arrays of equal length, each of which have names of at least 1 letter in them would work. If you have empty cells or if nam1 and nam2 are not the same length then it won't work.
What do nam1 and nam2 look like in a real case that fails? Giving a simplified example in a question is useful, but only if it replicates the problem you are having for the question you ask!
KDRA
2018년 10월 15일
카테고리
도움말 센터 및 File Exchange에서 Structures에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!