Hyコミュニティ、それは私のコードです。エラーや警告なしで実行されます。 ところで、x.df(最終的なデータベース)を見れば、SMA & Bollinger bandsの列に間違ったことがあります。 どちらも「NA」で埋められています。次に、BBandsはマージ後にいくつかの列を削除します。 どうしたの?ループ機能とquantmod
library(quantmod)
stockData <- new.env() #Make a new environment for quantmod to store data in
tickers <- c("AAPL","GOOG","YHOO","FB") # choose Symbols
start_date <- as.Date("2014-01-01") #Set start date
getSymbols(tickers, src="yahoo", env=stockData, from=start_date) # get data
x <- list()
# loop on tickers
for (i in 1:length(tickers)) {
x[[i]] <- get(tickers[i], pos=stockData) # get data from stockData environment
colnames(x[[i]]) <- c("Open", "High", "Low", "Close","Volume", "Adjusted") # rename Header for all tables in list
x[[i]]$gl <-((Cl(x[[i]])-Op(x[[i]]))/Op(x[[i]]))*100 # Daily gain loss percentage
SMA.n10 <- SMA(x[[i]][,4],n = 10) # Calculate moving averages (MA) on "Close Price" <-column(4)
BBands<- BBands(x[[i]][,2:4])
x[[i]]$Symbol<- 0 # create "0" vector for Symbol name
x[[i]]$Symbol<- tickers[[i]] # add Symbol name
x[[i]]<-data.frame(x[[i]],SMA.n10[[i]],BBands[[i]]) # merge data
}
x.df<- do.call(rbind, x) # call rbind to merge all xts objs in a single dataframe
おかげ
EDIT: 私の目標は、次の列を持つ単一のデータフレーム(x.df)を得ることである:
"オープン"、 "高"、 "低"、」 「ボリューム」、「調整済み」、シンボル、「SMA10」、「dn」、「mavg」、「up」、「pctB」の各項目が表示されます。
ただし、コードを実行すると、SMA列にNA値が表示されます。 ThentThereには "dn"、 "mavg"、 "up"、 "pctB"(Bollinger Bandsの値)に関するトレースはありません。
さらに詳しく... –