Sorting Column Variable to a Row
2 ビュー (過去 30 日間)
古いコメントを表示
I have been given my data in 3 Columns of a table as depicted in the below screenshot (I have had to try and replicate a similar scenario using excel as I can't share the actual data):
and I wish to have it in this format for easier analysis/plots such as surface plots, with NaN is cells where there is no value for that date and category:
Any help would be appreciated.
Thanks,
Huw
0 件のコメント
採用された回答
Stephen23
2021 年 6 月 16 日
編集済み: Stephen23
2021 年 6 月 16 日
Do NOT use loops for this, the inbuilt tools are much better! First lets create some fake data in a table:
C = randi(6,30,1);
D = datetime(2021,1,randi(3,30,1));
T = unique(table(D,C),'rows');
T.V = randi([10,100],height(T),1)/10
U = unstack(T,'V','C', 'VariableNamingRule','preserve')
3 件のコメント
Stephen23
2021 年 6 月 16 日
@Huw Wadkin: what options you have available depends on what MATLAB version you are using, which so far you have not told us. Use the local help of your installed MATLAB to know what options you can use.
"What do these options do?"
その他の回答 (1 件)
SALAH ALRABEEI
2021 年 6 月 16 日
編集済み: SALAH ALRABEEI
2021 年 6 月 16 日
Assume your table ( without labels) is of size nx3; where the 1st col is your dates (in numbers), 2nd is your cat, and the 3rd is the values. See this example
x=[ 1 1 1 2 2 2 2 3 3];
y=[0:8];
z=round(100*rand(1,9));
D = [x;y;z]';
a=unique(D(:,1));
B=nan*ones(length(a),size(D,1));
for i = 1:length(a)
B(i,a(i)==D(:,1))=D(a(i)==D(:,1),3);
end
0 件のコメント
参考
カテゴリ
Help Center および File Exchange で Categorical Arrays についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!