私はパッケージを使用しています: 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
この問題にどのように取り組むかについて、何かアイデアを提供できますか?
もう1つの情報:
reqIds()
への電話が必要かもしれないと思います。時々reqIds()
、十分に高くない ID が返されます。その後、私はそれを使用してplaceOrder()
失敗します。そのため、呼び出しますreqIds()
がSys.time()
、最後に使用した ID よりも大きい ID を取得するために使用します。
もう 1 つの問題は、PowerPoint からコピーしたコード テキストである可能性があります。コード文字の一部が破損している可能性があります。