4

私はR 3.1.1を搭載したMac OS 10.10を使用しています

次のデータ フレームがaありb、同じ属性があるとします。

a<- structure(list(X1 = 1:5, X2 = 6:10), .Names = c("X1", "X2"), row.names = c(NA, 
-5L), class = "data.frame")
b<- structure(list(X1 = 11:15, X2 = 16:20), .Names = c("X1", "X2"
), row.names = c(NA, -5L), class = "data.frame")

そして、元のデータフレームが次の目的の出力で変更を反映するように、両方で同時にaクリーニング/いくつかの機能(列のドロップや最初の列の2倍など)を適用する必要があるとします。b

> a
  X1 
1  2 
2  4 
3  6 
4  8
5 10

> b
  X1
1 22
2 24
3 26
4 28
5 30

for ループと *apply 関数を学習したばかりですが、それらをデータ フレームに適用すると混乱します (これはそうではありませんab、はるかに大きいです)。

4

1 に答える 1

5

同時に操作したいデータセットが複数ある場合は、それらすべてをリストに保持することを (R Core チームメンバーによって) 一般に推奨されています。目標を達成するために、単純に使用mgetlsてグローバル環境からそれらを取得し、最初の列を 2 倍したものに置き換えるだけです。

lapply(mget(ls(pattern = "[a-z]")), function(x) x <- x[1] * 2)
# $a
# X1
# 1  2
# 2  4
# 3  6
# 4  8
# 5 10
# 
# $b
# X1
# 1 22
# 2 24
# 3 26
# 4 28
# 5 30
于 2015-01-19T11:40:29.977 に答える