跳转到内容

实时价格推送

已订阅标的的实时价格推送,推送的数据结构中,只有有变化的字段才会填充数据。

行情权限要求基础行情
  • 美股:默认赠送 Nasdaq Basic 实时行情(含盘前、盘中、盘后时段);如需夜盘行情,需购买「LV1 实时行情 (OpenAPI)」行情卡,并开启夜盘配置(详见 Broker FAQ Q6、Q7)。
  • 港股:默认赠送 LV1 实时行情。
  • 美股期权:默认无权限,需购买「OPRA 美股期权行情 (OpenAPI)」行情卡。
Info

数据格式

Properties

NameTypeDescription
symbolstring标的代码,例如:AAPL.US
sequenceint64序列号
last_donestring最新价
openstring开盘价
highstring最高价
lowstring最低价
timestampint64最新成交的时间戳
volumeint64成交量
turnoverstring成交额
trade_statusint32交易状态,详见 TradeStatus
trade_sessionint32交易时段,详见 TradeSession
current_volumeint32两次推送之间增加的成交量
current_turnoverstring两次推送之间增加的成交额
tagint32价格数据标签

可选值:
0 - 实时行情
1 - 收盘后的修正数据

Protobuf

protobuf
message PushQuote {
  string symbol = 1;
  int64 sequence = 2;
  string last_done = 3;
  string open = 4;
  string high = 5;
  string low = 6;
  int64 timestamp = 7;
  int64 volume = 8;
  string turnover = 9;
  TradeStatus trade_status = 10;
  TradeSession trade_session = 11;
}

Example

python
from time import sleep
from longbridge.openapi import QuoteContext, Config, SubType, PushQuote, OAuthBuilder

def on_quote(symbol: str, event: PushQuote):
    print(symbol, event)

oauth = OAuthBuilder("your-client-id").build(lambda url: print("Visit:", url))
config = Config.from_oauth(oauth)
ctx = QuoteContext(config)
ctx.set_on_quote(on_quote)

ctx.subscribe(["700.HK", "AAPL.US"], [SubType.Quote])
sleep(30)

JSON Example

json
{
  "symbol": "AAPL.US",
  "sequence": 160808750000000,
  "last_done": "156.570",
  "open": "155.910",
  "high": "159.790",
  "low": "155.380",
  "timestamp": 1651089600,
  "volume": 88063191,
  "turnover": "13865092584.000",
  "trade_status": 0,
  "trade_session": 0,
  "current_volume": 111234,
  "current_turnover": "23234343454.000",
  "tag": 0
}