Ibpy с API Interactive Brokers не работает

Я чувствую, что что-то в корне не так. Я иду от примера кода к примеру кода, пробуя каждый, и у меня никогда не было никакого успеха.

Ниже приведен набор сценариев, которые я запускаю, и ответ. Большинство этих сценариев взяты из примера, найденного здесь в Stackru, с которым человек, похоже, добился успеха (после некоторой помощи). Увы, у меня нет успеха, и я просто чувствую, что с тем, что я делаю, должно быть что-то не так.

Прежде чем я начну со скриптов, которые, кажется, не работают, приведу мои конфиги для GUI Interactive brokers, TWS.

API - Настройки

проверил: включить ActiveX и Socket Clients. снят: включить клиенты DDE. не проверено: API только для чтения. проверил: скачать открытые ордера на соединение. проверил: при отправке портфолио включайте валютные позиции. проверил: отправлять обновления статуса для EEP. Порт сокета = 7496. флажок: использовать отрицательные числа для привязки автоматических заказов. снят: создание файла журнала сообщений API. снят: включение рыночных данных в файл журнала API. не отмечено: разрешать запросы учетной записи API переключать видимую пользователем подписку. Уровень ведения журнала = Ошибка. ИД клиента основного API = 100. Время ожидания для отправки массовых данных в API составляет 30 секунд. Компонент Exch Separator = Blank (здесь нет записей). проверил: разрешить соединения только с локального хоста.

API - Проверенные меры предосторожности: Обход мер предосторожности для заказов API. все остальное все не проверено в этой вкладке.

Пример 1

#test_conn.py

from ib.opt import ibConnection
con = ibConnection(port=7496,clientId=100)
print(con.connect())

Запуск сценария и ответ

C:\Users\alex>python test_conn.py
Server Version: 76
TWS Time at connection:20160314 16:13:59 ICT
True
True

Я думаю, что я могу подключиться к TWS тогда?

Пример 2

#test_portfolio.py

from ib.opt import ibConnection, message

def acct_update(msg):
    print(msg)

con = ibConnection(port=7496,clientId=100)
con.register(acct_update,
             message.updateAccountValue,
             message.updateAccountTime,
             message.updatePortfolio)
con.connect()
con.reqAccountUpdates(True,'DU358588')

#don't forget to disconnect somehow when done
con.disconnect()

Запуск сценария и ответ

C:\Users\alex>python test_portfolio.py
Server Version: 76
TWS Time at connection:20160314 16:25:59 ICT

C:\Users\alex>

Так что ничего не возвращается?

Пример 3

#test_mkt_data.py

from ib.opt import ibConnection, message
from ib.ext.Contract import Contract
from time import sleep

def my_callback_handler(msg):
    inside_mkt_bid = ''
    inside_mkt_ask = ''

    if msg.field == 1:
        inside_mkt_bid = msg.price
        print 'bid', inside_mkt_bid
    elif msg.field == 2:
        inside_mkt_ask = msg.price
        print 'ask', inside_mkt_ask

tws = ibConnection()
tws.register(my_callback_handler, message.tickSize, message.tickPrice)
tws.connect()

c = Contract()
c.m_symbol = "GOOG"
c.m_secType = "STK"
c.m_exchange = "SMART"
c.m_currency = "USD"

tws.reqMktData(1,c,"",False)
sleep(25)

print 'All done'

tws.disconnect()

Запуск сценария и ответ

C:\Users\alex>python test_mkt_data.py
Server Version: 76
TWS Time at connection:20160314 16:31:54 ICT
All done
Exception in thread EReader (likely raised during interpreter shutdown):
C:\Users\alex>

Опять ничего не возвращается?

Пример 4

#test_historical.py

from time import sleep, strftime
from time import sleep
from ib.ext.Contract import Contract
from ib.opt import ibConnection, message

def my_account_handler(msg):
    print(msg)

def my_tick_handler(msg):
    print(msg)

def my_hist_data_handler(msg):
    print(msg)


if __name__ == '__main__':

    con = ibConnection(port=7496,clientId=100)
    con.register(my_account_handler, 'UpdateAccountValue')
    con.register(my_tick_handler, message.tickSize, message.tickPrice)
    con.register(my_hist_data_handler, message.historicalData)
    con.connect()

    print(con.isConnected())

    def inner():

        qqqq = Contract()
        qqqq.m_secType = "STK" 
        qqqq.m_symbol = "GOOG"
        qqqq.m_currency = "USD"
        qqqq.m_exchange = "SMART"
        endtime = strftime('%Y%m%d %H:%M:%S')
    print(endtime)
        print(con.reqHistoricalData(1,qqqq,endtime,"5 D","1     hour","MIDPOINT",0,1))



        sleep(10)

    inner()
    sleep(5)
    print('disconnected', con.disconnect())
    print(con.isConnected())

Запуск сценария и ответ

C:\Users\alex>python test_historical.py
Server Version: 76
TWS Time at connection:20160314 16:38:03 ICT
True
20160314 16:38:04
None
('disconnected', True)
False

C:\Users\alex>

Нет исторических данных? Уберите "print" из "print(con.req..." по-прежнему без разницы).

Пример 5

# ib_api_demo.py

from ib.ext.Contract import Contract
from ib.ext.Order import Order
from ib.opt import Connection, message

def error_handler(msg):
    """Handles the capturing of error messages"""
    print "Server Error: %s" % msg

def reply_handler(msg):
    """Handles of server replies"""
    print "Server Response: %s, %s" % (msg.typeName, msg)

def create_contract(symbol, sec_type, exch, prim_exch, curr):
    """Create a Contract object defining what will
    be purchased, at which exchange and in which currency.

    symbol - The ticker symbol for the contract
    sec_type - The security type for the contract ('STK' is 'stock')
    exch - The exchange to carry out the contract on
    prim_exch - The primary exchange to carry out the contract on
    curr - The currency in which to purchase the contract"""
    contract = Contract()
    contract.m_symbol = symbol
    contract.m_secType = sec_type
    contract.m_exchange = exch
    contract.m_primaryExch = prim_exch
    contract.m_currency = curr
    return contract

def create_order(order_type, quantity, action):
    """Create an Order object (Market/Limit) to go long/short.

    order_type - 'MKT', 'LMT' for Market or Limit orders
    quantity - Integral number of assets to order
    action - 'BUY' or 'SELL'"""
    order = Order()
    order.m_orderType = order_type
    order.m_totalQuantity = quantity
    order.m_action = action
    return order

if __name__ == "__main__":
    # Connect to the Trader Workstation (TWS) running on the
    # usual port of 7496, with a clientId of 100
    # (The clientId is chosen by us and we will need 
    # separate IDs for both the execution connection and
    # market data connection)
    tws_conn = Connection.create(port=7496, clientId=100)
    tws_conn.connect()

    # Assign the error handling function defined above
    # to the TWS connection
    tws_conn.register(error_handler, 'Error')

    # Assign all of the server reply messages to the
    # reply_handler function defined above
    tws_conn.registerAll(reply_handler)

    # Create an order ID which is 'global' for this session. This
    # will need incrementing once new orders are submitted.
    order_id = 1

    # Create a contract in a stock via SMART order routing
    goog_contract = create_contract('BHP', 'STK', 'SMART', 'SMART', 'AUD')

    # Go long 100 shares of Google
    goog_order = create_order('MKT', 100, 'BUY')

    # Use the connection to the send the order to IB
    tws_conn.placeOrder(order_id, goog_contract, goog_order)

    # Disconnect from TWS
    tws_conn.disconnect()

бег и ответ

C:\Users\alex>python ib_api_demo.py
Server Version: 76
TWS Time at connection:20160314 16:43:55 ICT
Server Error: <error id=-1, errorCode=2104, errorMsg=Market data farm connection is OK:afarm>

Server Response: error, <error id=-1, errorCode=2104, errorMsg=Market data farm connection is OK:afarm>
C:\Users\alex>

Так что, кажется, ничего не работает, и я чувствую, что есть что-то фундаментальное, что я пропустил? TWS вошел в систему и работает, когда я запускаю скрипты на python, и настройки TWS API (см. Выше) кажутся правильными в отношении того, что все остальные говорят онлайн.

Любая помощь высоко ценится.

2 ответа

Решение

Я попробовал коды, которые вы предоставили.

Пример 2. Добавление sleep(1) перед con.disconnect()

Пример 3. tws = ibConnection() следует изменить на tws = ibConnection (порт =7496,clientId=100)

Пример 4, "1 час"-> слишком много пробелов, оставьте только один пробел и удалите лишние.

Пример 5. Будьте осторожны со следующим действующим идентификатором заказа. Он должен быть больше, чем идентификатор заказа в системе Ib. Вы можете использовать следующий код, чтобы получить следующий действующий идентификатор заказа из системы.:

def save_order_id(msg):

    print('Next Valid ID is ' + str(msg.orderId))

con = ibConnection(port=7496,clientId=100)

con.register(save_order_id, 'NextValidId')

con.connect()

sleep(1)

con.disconnect()

Вы хороши, чтобы пойти с вышеуказанными изменениями.

У меня была аналогичная проблема. Самой большой проблемой для меня была версия Python. Python 3.5.7 работал у меня. Однако мне все равно пришлось исправить некоторые проблемы совместимости версий Python.

Другие вопросы по тегам