2016-01-26 33 views
0

我想添加一个开放价格作为一个新的行在”SPY“数据框的末尾在生产使用quantmod包,我用下面的代码,以rbind新行,但我得到一个错误如何克服错误:“试图在一个小于两维的对象上设置'colnames'在xts对象

# rm(list = ls()) # generally considered as bad manner in an MWE 
require(quantmod) 
options(scipen=999) 
spy <- getSymbols(("SPY") , src = 'yahoo', from = '2016-01-01', auto.assign = T) 
spy<-cbind(SPY) 
tail(SPY) 
      SPY.Open SPY.High SPY.Low SPY.Close SPY.Volume SPY.Adjusted 
2016-01-14 189.55 193.26 187.66 191.93 240795600  191.93 
2016-01-15 186.77 188.76 185.52 187.81 324846400  187.81 
2016-01-19 189.96 190.11 186.20 188.06 190196000  188.06 
2016-01-20 185.03 187.50 181.02 185.65 280016900  185.65 
2016-01-21 186.21 188.87 184.64 186.69 189174000  186.69 
2016-01-22 189.78 190.76 188.88 190.52 163849600  190.52 

我想插入新行手动进间谍数据集,所以我试图创建一个新的xts对象,并使用rbind函数,但我得到一个错误后,这些行:

q <- c("2016-01-25",100,200,200,200,200,200) # creating the data 
colnames(q) <- colnames(SPY) # creating column names as in SPY 

但是我得到了一个错误:

Error in `colnames<-`(`*tmp*`, value = c("SPY.Open", "SPY.High", "SPY.Low", : 
    attempt to set 'colnames' on an object with less than two dimensions # creating the column names 

如何将这个手工制作的行添加到数据框的顶部?

+0

'q'是一个载体。一个向量没有列名。你可能希望'q < - data.frame(100,200,200,200,200,200)'但要小心'q'和'SPY'的'class'。 –

+0

你好@Pascal,我用你的建议和比使用rbind,但我得到这个错误:s <-rbind(SPY,q) 警告消息: 在rbind(SPY,q): 结果的列数不是一个向量长度的倍数(arg 2) – mql4beginner

+0

请参阅下面的答案。 –

回答

2

你可能想:

q <- data.frame(100,200,200,200,200,200) 
colnames(q) <- colnames(SPY) 
q <- xts(q, as.Date("2016-01-26")) 
#   SPY.Open SPY.High SPY.Low SPY.Close SPY.Volume SPY.Adjusted 
# 2016-01-26  100  200  200  200  200   200 

class(SPY) 
# [1] "xts" "zoo" 
class(q) 
# [1] "xts" "zoo" 

tail(rbind(SPY, q)) 
#   SPY.Open SPY.High SPY.Low SPY.Close SPY.Volume SPY.Adjusted 
# 2016-01-19 189.96 190.11 186.20 188.06 190196000  188.06 
# 2016-01-20 185.03 187.50 181.02 185.65 280016900  185.65 
# 2016-01-21 186.21 188.87 184.64 186.69 189174000  186.69 
# 2016-01-22 189.78 190.76 188.88 190.52 163849600  190.52 
# 2016-01-25 189.92 190.15 187.41 187.64 122676200  187.64 
# 2016-01-26 100.00 200.00 200.00 200.00  200  200.00 
相关问题