Hy community, Это мой код. Он работает без ошибок и предупреждений. Кстати, если вы посмотрите на x.df (окончательная база данных), то что-то не так на SMA & Полосы столбцов Боллинджера. Они оба заполнены «НА». Затем, BBands сбрасывает несколько столбцов после слияния. Что случилось?Loop function & 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: Моя цель состоит в том, чтобы получить единый dataframe (x.df) со следующими столбцами:
"Открыть", "High", "Low",» Close "," Volume "," Adjusted ", Symbol," SMA10 "," dn "," mavg "," up "," pctB ".
Но если вы запустите код, вы увидите значения NA в столбцах SMA. ThentThere не имеет никакого следа о «dn», «mavg», «up», «pctB» (значения полос Боллинджера).
описать подробнее ... –