R包IBrokers placeOrder()函数失败

时间:2014-10-30 04:01:05

标签: r ibrokers

我正在使用该软件包:IBrokers。当我请求历史数据时,它对我很有用。此外,对reqAccountUpdates()的调用效果也很好。

我遇到了这个脚本的问题:

# myscript.r

.libPaths("rpackages")
library(IBrokers)
tws2 = twsConnect(2)
print('Attempting BUY')
mytkr     = twsFuture("ES","GLOBEX","201412")
myorderid = sample(1001:3001, 1)
IBrokers:::.placeOrder(tws2, mytkr, twsOrder(myorderid, "BUY", "1", "MKT"))
twsDisconnect(tws2)

有时上面的脚本运行正常。通常虽然失败了。当它失败时,似乎连接好了。

然后我在TWS控制台中看到了这个:

03:47:45:581 JTS-EServerSocket-290: [2:47:71:1:0:0:0:ERR] Message type -1.  Socket I/O error - 
03:47:45:581 JTS-EServerSocket-290: Anticipated error
jextend.d: Socket I/O error - 
    at jextend.sc.b(sc.java:364)
    at jextend.ch.sb(ch.java:1534)
    at jextend.ch.run(ch.java:1390)
    at java.lang.Thread.run(Thread.java:745)
Caused by: java.net.SocketException: Connection reset
    at java.net.SocketInputStream.read(SocketInputStream.java:196)
    at java.net.SocketInputStream.read(SocketInputStream.java:122)
    at java.net.SocketInputStream.read(SocketInputStream.java:210)
    at jextend.xh.d(xh.java:45)
    at jextend.sc.c(sc.java:579)
    at jextend.sc.r(sc.java:227)
    at jextend.af.a(af.java:232)
    at jextend.sc.f(sc.java:650)
    at jextend.pd.a(pd.java:822)
    at jextend.sc.b(sc.java:358)
    ... 3 more
03:47:45:583 JTS-EServerSocket-290: [2:47:71:1:0:0:0:ERR] Socket connection for client{2} has closed. 
03:47:45:583 JTS-EWriter14-291: [2:47:71:1:0:0:0:ERR] Unable write to socket client{2} - 
03:47:45:584 JTS-EServerSocketNotifier-288: Terminating

您能否就如何解决这个问题提出任何想法?

另一条信息:

我认为可能需要拨打reqIds()。有时reqIds()会返回不够高的ID。然后,我会使用它,placeOrder()会失败。所以,我拨打reqIds(),然后使用Sys.time()给我一个比我上次使用的ID大的ID。

另一个问题可能是我从PowerPoint中复制的一些代码文本。某些代码字符可能已损坏。

1 个答案:

答案 0 :(得分:0)

主要问题是orderid。

我需要小心如何生成orderid。

此外,我可能已经从一个有一个例子的powerpoint中输入了坏人物。

我发布了一些代码,这些代码在这个帖子的评论中有用。