1

我想遍历一些公司代码的 CSV 并下载它们各自的代码数据。

到目前为止,我已经将变量“ticker”定义如下:

ticker <- companyList[1, 'Symbol']

当我在屏幕上打印“ticker”时,它显示第一个股票代码非常好,但是当我尝试将代码变量传递给 quantmod 的 getSymbols 函数时,我得到一个错误。

getSymbols(ticker)
Error in do.call(paste("getSymbols.", symbol.source, sep = ""), list(Symbols =   current.symbols;  : 
 could not find function "getSymbols.940"

我的语法有错误吗?还有其他方法可以做到这一点吗?有什么书推荐吗?

4

1 回答 1

2

最简单的方法是指定一个环境,例如假设您有一个带有代码的向量,您可以执行以下操作:

# tickers example
tik <- c("MMM", "ABT", "ABBV", "ANF", "ACT")

# new environment
stockData <- new.env() 

# download data
getSymbols(tik, env = stockData)

比您可以索引来访问股票:例如:

stockData$MMM

           MMM.Open MMM.High MMM.Low MMM.Close MMM.Volume MMM.Adjusted
# 2007-01-03    77.53    78.85   77.38     78.26    3781500        65.42
# 2007-01-04    78.40    78.41   77.45     77.95    2968400        65.16
# 2007-01-05    77.89    77.90   77.01     77.42    2765200        64.72
# 2007-01-08    77.42    78.04   76.97     77.59    2434500        64.86
# 2007-01-09    78.00    78.23   77.44     77.68    1896800        64.93
# 2007-01-10    77.31    77.96   77.04     77.85    1787500        65.07

其他所有股票都一样。

也可以在这里查看:Quantmod

hth

编辑

对于导出,您可以使用以下内容:

# this will export 
lapply(stockData, function(x){
  write.csv(x, file=paste0(gsub(".Open", "", names(x)[1]), ".csv"))
    })

# the data can be found in the folder (execute the function!!!)
getwd()
于 2013-10-15T06:14:59.980 回答