首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >R/ quantstrat / applyStrategy

R/ quantstrat / applyStrategy
EN

Stack Overflow用户
提问于 2018-07-25 21:36:17
回答 1查看 232关注 0票数 1

请忽略我以前的帖子。我正试着在quantstrat上执行一项贸易策略,现在我被困住了。任何帮助都将不胜感激。代码如下,运行applyStrategy时会收到以下错误:

错误的if (继承(sret$指示符,"xts")和nrow(mktdata) == nrow(sret$指示符)){:参数长度为零

代码:

代码语言:javascript
复制
getSymbols("AUD=X",src="yahoo",from="1975-01-02")
colnames(`AUD=X`) <- c("Open", "High", "Low", "Close", "Vol", "Adj")

if (!exists('.blotter')) .blotter <- new.env()
.strategy <- new.env()

initdate = as.character("2006-05-15")
from = as.character("2007-05-15")
to = as.character("2018-06-01")
Sys.setenv(TZ = "UTC")
currency("USD")
stock(`AUD=X`, currency="USD", multiplier = 1)

tradesize <- 100000
initeq <- 100000
strategy.st <- portfolio.st <- account.st <- "firststrat"

rm.strat(strategy.st)
initPortf(portfolio.st, symbols = na.locf("AUD=X"), initDate = initdate, currency = "USD")
initAcct(account.st, portfolios = portfolio.st, initDate = initdate, currency = "USD", initEq = initeq)
initOrders(portfolio.st, initDate = initdate)
strategy(strategy.st, store = TRUE)

add.indicator(strategy = strategy.st,
          name = "SMA",
          arguments = list(x = quote(na.omit(Cl(mktdata))), n = 200),
          label = "SMA200")

add.indicator(strategy = strategy.st,
          name = "SMA",
          arguments = list(x = quote(na.omit(Cl(mktdata))), n = 50),
          label = "SMA50")

test <- applyIndicators(strategy = strategy.st, mktdata = na.locf(Cl(`AUD=X`)))
tail(test)

add.signal(strategy.st,
       name = "sigCrossover",
       arguments = list(columns = c("SMA.SMA50", "SMA.SMA200"),
       relationship = "gt"),
       label = "Crossover")

add.signal(strategy.st,
       name = "sigComparison",
       arguments = list(columns = c("SMA.SMA50", "SMA.SMA200"),
       relationship = "lt"),
       label = "Compare")

add.signal(strategy.st,
       name = "sigThreshold",
       arguments = list(column = "Close",
                        threshold = 1.5,
                        cross = FALSE,
                        relationship = "lt"),
       label = "threshold_high")

add.signal(strategy.st,
       name = "sigThreshold",
       arguments = list(column = "Close",
                        threshold = 1,
                        cross = FALSE,
                        relationship = "gt"),
       label = "threshold_low")

test2 <- applySignals(strategy = strategy.st, mktdata = test)
tail(test2)
add.rule(strategy.st, name = "ruleSignal",
     arguments = list(sigcol = "threshold_low", sigval = FALSE,
                      orderqty = "all", ordertype = "market",
                      orderside = "short", replace = FALSE,
                      prefer = "Open"),
     type = "enter")

add.rule(strategy.st, name = "ruleSignal",
     arguments = list(sigcol = "threshold_high", sigval = TRUE,
                      orderqty = "all", ordertype = "market",
                      orderside = "long", replace = FALSE,
                      prefer = "Open"),
     type = "enter")


applyStrategy(strategy = strategy.st, portfolios = portfolio.st)
EN

回答 1

Stack Overflow用户

发布于 2018-07-30 14:19:58

雅虎API一年多前就被关闭了。试试这个吧。

代码语言:javascript
复制
library(quantmod)


# enter tickers to download time-series data
e <- new.env()
getSymbols("SBUX", env = e)
pframe <- do.call(merge, as.list(e))
head(pframe)

你也可以试试这个。

代码语言:javascript
复制
library(quantmod)
library(tidyverse) # rather than just dplyr
df <- data.frame(getSymbols(Symbols = 'SBUX', env = NULL))

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51528034

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档