# 實時分時回呼

on_recv_rsp(self, rsp_pb)

  • 介紹

    實時分時回呼,非同步處理已訂閲股票的實時分時推送。
    在收到實時分時數據推送後會回呼到該函數,您需要在衍生類別中覆寫 on_recv_rsp。

  • 參數

    參數 類型 説明
    rsp_pb Qot_UpdateRT_pb2.Response 衍生類別中不需要直接處理該參數
  • 返回

    參數 類型 説明
    ret RET_CODE 介面呼叫結果
    data pd.DataFrame 當 ret == RET_OK,返回分時數據
    str 當 ret != RET_OK,返回錯誤描述
    • 分時數據格式如下:
      欄位 類型 説明
      code str 股票代碼
      name str 股票名稱
      time str 時間
      is_blank bool 數據狀態
      opened_mins int 零點到當前多少分鐘
      cur_price float 當前價格
      last_close float 昨天收盤的價格
      avg_price float 平均價格
      volume float 成交量
      turnover float 成交金額
  • Example

import time
from moomoo import *

class RTDataTest(RTDataHandlerBase):
    def on_recv_rsp(self, rsp_pb):
        ret_code, data = super(RTDataTest, self).on_recv_rsp(rsp_pb)
        if ret_code != RET_OK:
            print("RTDataTest: error, msg: %s" % data)
            return RET_ERROR, data
        print("RTDataTest ", data) # RTDataTest 自己的處理邏輯
        return RET_OK, data
quote_ctx = OpenQuoteContext(host='127.0.0.1', port=11111)
handler = RTDataTest()
quote_ctx.set_handler(handler)  # 設定實時分時推送回呼
ret, data = quote_ctx.subscribe(['US.AAPL'], [SubType.RT_DATA], session=Session.ALL) # 訂閲分時類型,OpenD 開始持續收到伺服器的推送
if ret == RET_OK:
    print(data)
else:
    print('error:', data)
time.sleep(15)  # 設定腳本接收 OpenD 的推送持續時間為15秒
quote_ctx.close()   # 關閉當條連線,OpenD 會在1分鐘後自動取消相應股票相應類型的訂閲    
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
  • Output
RTDataTest        code name                 time  is_blank  opened_mins  cur_price  last_close   avg_price   turnover  volume
0  US.AAPL   蘋果  2025-04-07 05:24:00     False          324     179.53      188.38  180.465762  651262.42    3624
1
2

提示