test
列名を持つデータ フレーム オブジェクトがあります。
> test
a b c d e
1 -0.67 -0.02 -0.10 -0.22 -0.32
2 0.46 -1.51 -0.79 0.26 1.19
3 0.22 -0.18 -1.40 0.41 -0.32
4 -2.21 0.79 0.36 1.00 -0.51
5 -0.69 0.39 -0.76 -0.73 -0.43
test$b
この形式では、表記法を使用して列に簡単にアクセスできます。これを問題なく時系列オブジェクトに変換できます。
test.ts <- ts(test, frequency=<value>, start=<value>
ただし、ts
オブジェクトになったら、列番号ではなく名前で列 (または行) にアクセスする簡単な方法はありますか? test.ts
オブジェクトには、次を使用して表示される列名情報がまだありcolnames
ます。
> colnames(test.ts)
[1] "a" "b" "c" "d" "e"
ただし、test.ts$b
機能しません。「簡単に」とはtest.ts[,which(colnames(test.ts)=="b"]
、 のような醜いものを書かないことを意味することに注意してください。それは簡単ではないため、醜いからです。はい、それを行う独自の関数を作成できますが、これを行う組み込みの方法があるかどうか疑問に思っていました。ありがとう!
リクエストに応じて:
> dput(head(a))
structure(list(a = c(-0.67, 0.46, 0.22, -2.21, -0.69, -0.45),
b = c(-0.02, -1.51, -0.18, 0.79, 0.39, -1.33), c = c(-0.1,
-0.79, -1.4, 0.36, -0.76, 0.15), d = c(-0.22, 0.26, 0.41,
1, -0.73, -2.23), e = c(-0.32, 1.19, -0.32, -0.51, -0.43,
-0.58)), .Names = c("a", "b", "c", "d", "e"), row.names = c(NA,
6L), class = "data.frame")