필터 지우기
필터 지우기

How to deal with table

조회 수: 2 (최근 30일)
Ahmad Bayhaqi
Ahmad Bayhaqi 2021년 4월 12일
댓글: Ahmad Bayhaqi 2021년 4월 13일
Hi All, I have table, named as newT consisting of data value and position(latitude and longitude). What I want to do is:
  1. How to delete empty cell in the table?
2. How to some operationss with them? each cell in each grid contains, I want to do sum operation (for example in the figure above: 16+57+202......) and average in each rows. Then, the calculation is the same for all grids.
Any helps is greaty appreciated.
Thank you

채택된 답변

Walter Roberson
Walter Roberson 2021년 4월 12일
Removing entries that have empty exData:
mask = cellfun(@isempty, newT.exData);
newT(mask,:) = [];
If I understand correctly, each row of exData contains a cell array that contains cells with variable number of numeric entries. If so then
result1 = cellfun(@(C) cellfun(@sum, C), newT.exData, 'uniform', 0)
The result would be a cell array with one entry for each row in newT, and the entries would be vectors that were the sums. If you then wanted to take the average of those sums, then
result2 = cellfun(@mean, result1)
which would give you a numeric vector, one entry per row in newT.
  댓글 수: 3
Walter Roberson
Walter Roberson 2021년 4월 12일
Have you considered
result3 = cellfun(@(C) cellfun(@mean, C), newT.exData, 'uniform', 0)
instead of having to count and divide yourself ?
... I am not clear as to what is being averaged, to be honest.
Ahmad Bayhaqi
Ahmad Bayhaqi 2021년 4월 13일
Thank you so much for your great help.
I get inspiration from your answer.
Big thanks

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Creating and Concatenating Matrices에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by