複数の列の値に基づいて複数のデータフレームを取得するデータフレームをサブセット化しようとしています。これが私の例です
>df
v1 v2 v3 v4 v5
A Z 1 10 12
D Y 10 12 8
E X 2 12 15
A Z 1 10 12
E X 2 14 16
期待される出力は次のようになります。このデータフレームを列v1
に基づいて複数のデータフレームに分割し、v2
>df1
v3 v4 v5
1 10 12
1 10 12
>df2
v3 v4 v5
10 12 8
>df3
v3 v4 v5
2 12 15
2 14 16
私は現在機能しているコードを書きましたが、それが最善の方法だとは思いません。それを行うためのより良い方法があるはずです。tab
初期データを持つdata.frameであると仮定します。これが私のコードです:
v1Factors<-levels(factor(tab$v1))
v2Factors<-levels(factor(tab$v2))
for(i in 1:length(v1Factors)){
for(j in 1:length(v2Factors)){
subsetTab<-subset(tab, v1==v1Factors[i] & v2==v2Factors[j], select=c("v3", "v4", "v5"))
print(subsetTab)
}
}
誰かが上記を行うためのより良い方法を提案できますか?