gpt4 book ai didi

python-3.x - 将盈透证券 API 引入 Pandas

转载 作者:行者123 更新时间:2023-12-03 23:51:06 25 4
gpt4 key购买 nike

Python 和 IB API 的新手并坚持这个简单的事情。 This application工作正常并打印 IB 服务器回复。但是,我无法弄清楚如何将这些数据放入 Pandas 的数据框或任何其他与此相关的变量。你如何“获取数据”?谢谢!

我在论坛、文档或 YouTube 上找不到任何有用的示例。我认为答案必须是将 accountSummary 返回到 pd.Series,但不知道如何。

预期输出将是可以在应用程序外部操作的数据系列或变量。

from ibapi import wrapper
from ibapi.client import EClient
from ibapi.utils import iswrapper #just for decorator
from ibapi.common import *
import pandas as pd

class TestApp(wrapper.EWrapper, EClient):
def __init__(self):
wrapper.EWrapper.__init__(self)
EClient.__init__(self, wrapper=self)

@iswrapper
def nextValidId(self, orderId:int):
print("setting nextValidOrderId: %d", orderId)
self.nextValidOrderId = orderId
# here is where you start using api
self.reqAccountSummary(9002, "All", "$LEDGER")

@iswrapper
def error(self, reqId:TickerId, errorCode:int, errorString:str):
print("Error. Id: " , reqId, " Code: " , errorCode , " Msg: " , errorString)

@iswrapper
def accountSummary(self, reqId:int, account:str, tag:str, value:str, currency:str):
print("Acct Summary. ReqId:" , reqId , "Acct:", account,
"Tag: ", tag, "Value:", value, "Currency:", currency)
#IB API data returns here, how to pass it to a variable or pd.series

@iswrapper
def accountSummaryEnd(self, reqId:int):
print("AccountSummaryEnd. Req Id: ", reqId)
# now we can disconnect
self.disconnect()

def main():
app = TestApp()
app.connect("127.0.0.1", 4001, clientId=123)
test = app.accountSummary
app.run()

if __name__ == "__main__":
main()

最佳答案

嗨,有同样的问题,收藏为我做了。这是我的差价合约数据代码。也许它会帮助某人。您将在 app.df 中拥有您的数据。任何改进建议都非常受欢迎。

import collections
import datetime as dt
from threading import Timer
from ibapi.client import EClient
from ibapi.wrapper import EWrapper
from ibapi.contract import Contract
import pandas as pd

# get yesterday and put it to correct format yyyymmdd{space}{space}hh:mm:dd
yesterday = str(dt.datetime.today() - dt.timedelta(1))
yesterday = yesterday.replace('-','')

IP = '127.0.0.1'
PORT = 7497

class App(EClient, EWrapper):

def __init__(self):
super().__init__(self)
self.data = collections.defaultdict(list)

def error(self, reqId, errorCode, errorString):
print(f'Error {reqId}, {errorCode}, {errorString}')

def historicalData(self, reqId, bar):
self.data['date'].append(bar.date)
self.data['open'].append(bar.open)
self.data['high'].append(bar.high)
self.data['low'].append(bar.low)
self.data['close'].append(bar.close)
self.data['volume'].append(bar.volume)
self.df = pd.DataFrame.from_dict(self.data)

def stop(self):
self.done = True
self.disconnect()

# create App object
app = App()
print('App created...')
app.connect(IP, PORT, 0)
print('App connected...')

# create contract
contract = Contract()
contract.symbol = 'IBDE30'
contract.secType = 'CFD'
contract.exchange = 'SMART'
contract.currency = 'EUR'
print('Contract created...')

# request historical data for contract
app.reqHistoricalData(reqId=1,
contract=contract,
endDateTime=yesterday,
durationStr='1 W',
barSizeSetting='15 mins',
whatToShow='ASK',
useRTH=0,
formatDate=1,
keepUpToDate=False,
chartOptions=[])

Timer(4, app.stop).start()
app.run()

关于python-3.x - 将盈透证券 API 引入 Pandas,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57799021/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com