2017-10-08 70 views
1

我想合并在我创建的新环境中的所有(xts)对象。我想到的最好的是使用eapply函数的以下内容。我使用了eapply,因为它采用了环境中的所有对象,我不能想出更好的东西。如何合并环境中的所有xts对象

这将采取每个对象的值的头,但我想整个对象。

plist <- eapply(dataEnv, head) 
pframe <- do.call(merge, plist) 

回答

2

既然您想要整个对象,您可以简单地将环境转换为列表。然后合并使用do.call(),就像你已经完成。例如:

library(quantmod) 
e <- new.env() 
getSymbols("IBM;MSFT", env = e) 
pframe <- do.call(merge, as.list(e)) 
head(pframe) 
#   IBM.Open IBM.High IBM.Low IBM.Close IBM.Volume IBM.Adjusted 
# 2007-01-03 97.18 98.40 96.26  97.27 9196800  76.18299 
# 2007-01-04 97.25 98.79 96.88  98.31 10524500  76.99751 
# 2007-01-05 97.60 97.95 96.91  97.42 7221300  76.30047 
# 2007-01-08 98.50 99.50 98.35  98.90 10340000  77.45959 
# 2007-01-09 99.08 100.33 99.07 100.07 11108200  78.37598 
# 2007-01-10 98.50 99.05 97.93  98.89 8744800  77.45180 
#   MSFT.Open MSFT.High MSFT.Low MSFT.Close MSFT.Volume MSFT.Adjusted 
# 2007-01-03  29.91  30.25 29.40  29.86 76935100  23.08097 
# 2007-01-04  29.70  29.97 29.44  29.81 45774500  23.04231 
# 2007-01-05  29.63  29.75 29.45  29.64 44607200  22.91091 
# 2007-01-08  29.65  30.10 29.53  29.93 50220200  23.13508 
# 2007-01-09  30.00  30.18 29.73  29.96 44636600  23.15826 
# 2007-01-10  29.80  29.89 29.43  29.66 55017400  22.92637 
+0

谢谢!事实上,在我发布之前,我试图做到这一点,但得到了一些神秘的错误消息。它现在有效))) – user8369515