# 期權異動推送

class OptionEventHandlerBase(RspHandlerBase)

  • 介紹

    接收期權異動推送,當設置的異動提醒被觸發時,服務端會主動推送異動信息。需先通過 set_option_event_alert 設置提醒條件,並通過 handler 註冊回調。用戶繼承 OptionEventHandlerBase 並重寫 on_recv_rsp 方法來接收推送。

  • 參數

    on_recv_rsp 回調返回 (ret_code, content),content 為 dict:

    參數 類型 說明
    owner_code str 標的代碼(如 'US.TSLA')
    option_code str 期權合約代碼(如 'US.TSLA250620C250')
    message str 推送消息文本
  • Example

from futu import *

class OptionEventHandler(OptionEventHandlerBase):
    def on_recv_rsp(self, rsp_pb):
        ret_code, content = super(OptionEventHandler, self).on_recv_rsp(rsp_pb)
        if ret_code != RET_OK:
            print("OptionEvent error:", content)
            return RET_ERROR, content

        print("收到期權異動推送:")
        print("  標的:", content['owner_code'])
        print("  期權:", content['option_code'])
        print("  消息:", content['message'])
        return RET_OK, content

quote_ctx = OpenQuoteContext(host='127.0.0.1', port=11111)

# 註冊期權異動推送處理器
quote_ctx.set_handler(OptionEventHandler())

# 需要先通過 set_option_event_alert 設置提醒條件,推送才會觸發
item = OptionEventAlertItem(
    option_market=OptionMarket.US_SECURITY,
    option_type=OptionType.CALL,
    order_type_list=[AlertOrderType.SWEEP],
    size_range_min=100,
)
ret, data = quote_ctx.set_option_event_alert(AlertOpType.ADD, item)
if ret == RET_OK:
    print('提醒設置成功,等待推送...')
else:
    print('設置失敗:', data)

import time
try:
    while True:
        time.sleep(1)
except KeyboardInterrupt:
    pass

quote_ctx.close()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
  • Output
收到期權異動推送:
  標的: US.TSLA
  期權: US.TSLA250620C250
  消息: TSLA $250 Call 06/20 大額掃單 500張 成交價$12.50
1
2
3
4