首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >quantStrat无法识别列名

quantStrat无法识别列名
EN

Stack Overflow用户
提问于 2014-10-20 05:19:25
回答 1查看 565关注 0票数 2

我编写了以下代码,并在应用该策略时收到错误消息:

eval(expr,envir,enclos)出错:找不到对象'Close‘

听起来策略找不到列" Close“的价格,而最后一行代码"head(mktdata)”清楚地给出了XLB.Close作为Close的列名。

顺便说一句,我有意省略了不需要的add.indicator()函数。

有人能帮上忙吗?谢谢

代码输出的最后一行的列名为XLB.Close:

代码语言:javascript
复制
head(mktdata)    
           XLB.Open XLB.High  XLB.Low XLB.Close XLB.Volume XLB.Adjusted    
2010-01-04 30.66197 31.06374 30.54327  31.06374    8287681        30.31

使用quantstrat的策略代码:

代码语言:javascript
复制
library(quantstrat)
startDate <- '2010-01-01'  # start of data    
endDate <-  '2013-07-31'   # end of data    
symbols = c("XLF", "XLP", "XLE", "XLY", "XLV", "XLI", "XLB", "XLK", "XLU")    
Sys.setenv(TZ="UTC")       # set time zone

getSymbols(symbols, src='yahoo', index.class=c("POSIXt","POSIXct"),    
           from=startDate, to=endDate, adjust=TRUE)    

initDate <- '2009-12-31'   
initEq <- 1e6   
currency("USD")  
stock(symbols, currency="USD",multiplier=1)   
head(XLB)   
Lowcut1<-1.001   
Lowcut2<-1.002   

rm.strat("multiINTRO") # remove portfolio, account, orderbook if re-run    
initPortf(name="multiINTRO", symbols, initDate=initDate)    
initAcct(name="multiINTRO", portfolios="multiINTRO",
         initDate=initDate, initEq=initEq)    
initOrders(portfolio="multiINTRO", initDate=initDate)    


strategy("multiINTRO", store=TRUE)    
summary(getStrategy("multiINTRO"))    

add.signal("multiINTRO", name="sigFormula",
           arguments=list(columns=c("Close","Low"),
                          formula="(Close > Lowcut1*Low) & (Close< Lowcut2*Low)",
                          cross=FALSE),store=TRUE,env=globalenv(),
           label="longLowenter") ##Long entry


add.rule("multiINTRO", name="ruleSignal", 
         arguments=list(sigcol="longLowenter", sigval=TRUE, orderqty=100,
                        ordertype="market", orderside="long"), type="enter") ## Long enter


out<-try(applyStrategy("multiINTRO",portfolios="multiINTRO"))    
head(mktdata)
EN

回答 1

Stack Overflow用户

发布于 2014-10-20 20:11:51

head(mktdata)清楚地给出了"XLB.Close"作为列名,"XLB.Close" != "Close"作为列名。在市场数据上使用quantmod的ClLo列提取器来获得你想要的列。

此外,您的formula参数是错误的,因为它是字符串,而不是公式。如果我将您的add.signal调用更改为:

代码语言:javascript
复制
add.signal("multiINTRO", name="sigFormula",
  arguments=list(formula=longLowenter ~ Cl(mktdata) > Lowcut1*Lo(mktdata) & Cl(mktdata)< Lowcut2*Lo(mktdata), cross=FALSE), store=TRUE, env=globalenv(),
  label="longLowenter") ##Long entry
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26455528

复制
相关文章

相似问题

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