データセットやテーブルはどのように転置しますか?

24 次查看(过去 30 天)
MathWorks Support Team
データセットやテーブルのデータを転置したいのですが、どのようにすればよいでしょうか?
例えば以下のようなデータセットがあるとします。
>> X = dataset({[1;2], 'a'}, {[100;200], 'b'}, 'ObsNames', {'c','d'})
X =
a b
c 1 100
d 2 200
これを以下のようにする方法です。
>> Xt = X'
Xt =
c d
a 1 2
b 100 200
同様に、以下のようなテーブルを
>> X = array2table([1 100; 2 200],'VariableNames',{'a','b'},'RowNames',{'c','d'})
X =
a b
_ ___
c 1 100
d 2 200
以下のようにする方法です。
>> Xt = X'
Xt =
c d
___ ___
a 1 2
b 100 200

采纳的回答

MathWorks Support Team
データセットやテーブルは転置することはできず、セルを使用したプログラミングで対処します。
データセットの場合はdataset2cellやcell2datasetを使用します。
>> Xc = dataset2cell(X)
Xc =
'ObsNames' 'a' 'b'
'c' [1] [100]
'd' [2] [200]
>> Xt = cell2dataset(Xc','ReadObsNames',true)
Xt =
c d
a 1 2
b 100 200
テーブルの場合はtable2cellやcell2tableを使用します。
>> Xc = table2cell(X)
Xc =
[1] [100]
[2] [200]
>> Xt = cell2table(Xc','RowNames',X.Properties.VariableNames,'VariableNames',X.Properties.RowNames)
Xt =
c d
___ ___
a 1 2
b 100 200
なお、R2018aからはrows2varsコマンドが提供されています。
<https://www.mathworks.com/help/matlab/ref/rows2vars.html>

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 table 的更多信息

标签

尚未输入任何标签。

产品


版本

R2018a

Community Treasure Hunt

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

Start Hunting!