Using cellfun to extract numbers from strings in a cell array
조회 수: 7 (최근 30일)
이전 댓글 표시
Hi all,
I currently have the following code which extracts numbers from strings found within a cell array.
Cel = {'1-2-3-4-5-6' '5-6-7-8'} ;
fun = @(X) cellfun(@(C) abs(sscanf(C,'%d')), X, 'Un', 0) ;
xx = fun(Cel)
This works great. But my problem is that I have a case in my cell array with empty cells, like so:
Cel = {'1-2-3-4-5-6' '5-6-7-8' [] []} ;
fun = @(X) cellfun(@(C) abs(sscanf(C,'%d')), X, 'Un', 0) ;
xx = fun(Cel)
I would like for the code to return xx = {[1 2 3 4 5 6] [5 6 7 8] [] []}, but obviously since my function does not work with empty cells, I get an error.
So I would like to know what alternatives do I have such that I can accomplish the above?
댓글 수: 0
채택된 답변
Yongjian Feng
2021년 11월 4일
How about this:
Cel = {'1-2-3-4-5-6' '5-6-7-8' [] []} ;
xx = cellfun(@(x) foo(x), Cel, 'Un', 0);
function ret = foo(x)
ret = [];
if ~isempty(x)
ret = abs(sscanf(x, "%d"));
end
end
댓글 수: 0
추가 답변 (0개)
참고 항목
카테고리
Help Center 및 File Exchange에서 Cell Arrays에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!