Hy Community, das ist mein Code. Es läuft ohne Fehler oder Warnung. Übrigens, wenn Sie auf x.df (endgültige Datenbank) schauen, ist bei SMA & Bollinger Bands Spalten etwas falsch. Sie sind beide "NA" gefüllt. Dann löscht BBands einige Spalten nach der Zusammenführung. Was ist los?Loop-Funktion & 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
Dank
EDIT: Mein Ziel ist es, einen einzelnen Datenrahmen (x.df) mit den folgenden Spalten zu erhalten:
"Öffnen", "Hoch", "Niedrig",“ Close "," Volume "," Adjusted ", Symbol," SMA10 "," dn "," mavg "," auf "," pctB ".
Aber wenn Sie den Code ausführen, können Sie NA-Werte auf SMA-Säulen sehen. ThentEs gibt keine Spur über "dn", "mavg", "up", "pctB" (Bollinger Bands Werte).
beschreiben mehr ... –