# 到達価格アラートコールバック
- Python
- Proto
- C#
- Java
- C++
- JavaScript
on_recv_rsp(self, rsp_pb)
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
リアルタイム到達価格アラート通知プッシュの受信時にこの関数がコールバックされます。派生クラスで on_recv_rsp をオーバーライドしてください。パラメータ
パラメータ 型 説明 rsp_pb Qot_UpdatePriceReminder_pb2.Response 派生クラスでは直接処理不要
戻り値
パラメータ 型 説明 ret RET_CODE API呼び出し結果 data dict 当 ret == RET_OK,返す到達価格アラート str ret != RET_OK の場合、エラーの説明を返す - 到達価格アラート
フィールド タイプ 説明 code str 銘柄コード name str 銘柄名 price float 現在の価格 change_rate str 現在の騰落率 market_status PriceReminderMarketStatus トリガーの時間帯 content str 到達価格アラート文字内容 note str 備考 最大20文字まで対応key int 到達価格アラート識別子 reminder_type PriceReminderType 到達価格アラートのタイプ set_value float 用户設定したアラート値 cur_value float アラートトリガー時の値
- 到達価格アラート
Example
import time
from futu import *
class PriceReminderTest(PriceReminderHandlerBase):
def on_recv_rsp(self, rsp_pb):
ret_code, content = super(PriceReminderTest,self).on_recv_rsp(rsp_pb)
if ret_code != RET_OK:
print("PriceReminderTest: error, msg: %s" % content)
return RET_ERROR, content
print("PriceReminderTest ", content) # PriceReminderTest 独自の処理ロジック
return RET_OK, content
quote_ctx = OpenQuoteContext(host='127.0.0.1', port=11111)
handler = PriceReminderTest()
quote_ctx.set_handler(handler) # 到達価格アラート通知コールバックを設定
time.sleep(15) # スクリプトが OpenD のプッシュを受信する時間を15秒に設定
quote_ctx.close() # 接続をクローズすると、OpenD は1分後に対応銘柄の登録を自動解除
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
- Output
PriceReminderTest {'code': 'US.AAPL', 'name': '苹果', 'price': 185.750, 'change_rate': 0.11, 'market_status': 'US_PRE', 'content': '買一価高于185.500', 'note': '', 'key': 1744022257052794489, 'reminder_type': 'BID_PRICE_UP', 'set_value': 185.500, 'cur_value': 185.750}
# Qot_UpdatePriceReminder.proto
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
プロトコル ID
3019
virtual void OnReply_UpdatePriceReminder(FTAPI_Conn client, uint nSerialNo, QotUpdatePriceReminder.Response rsp);
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
- Example
public class Program : FTSPI_Qot, FTSPI_Conn {
FTAPI_Qot qot = new FTAPI_Qot();
public Program() {
qot.SetClientInfo("csharp", 1); //クライアント情報の設定
qot.SetConnCallback(this); //接続コールバックの設定
qot.SetQotCallback(this); //取引コールバックの設定
}
public void Start() {
qot.InitConnect("127.0.0.1", (ushort)11111, false);
}
public void OnInitConnect(FTAPI_Conn client, long errCode, String desc)
{
Console.Write("Qot onInitConnect: ret={0} desc={1} connID={2}\n", errCode, desc, client.GetConnectID());
if (errCode != 0)
return;
}
public void OnDisconnect(FTAPI_Conn client, long errCode) {
Console.Write("Qot onDisConnect: {0}\n", errCode);
}
public void OnReply_UpdatePriceReminder(FTAPI_Conn client, uint nSerialNo, QotUpdatePriceReminder.Response rsp)
{
Console.Write("Reply: QotUpdatePriceReminder: {0}\n", nSerialNo);
Console.Write("code: {0}, content: {1}\n", rsp.S2C.Security.Code, rsp.S2C.Content);
}
public static void Main(String[] args) {
FTAPI.Init();
Program qot = new Program();
qot.Start();
while (true)
Thread.Sleep(1000 * 600);
}
}
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
42
- Output
Qot onInitConnect: ret=0 desc= connID=6826796032557005979
Reply: QotUpdatePriceReminder: 4
code: VXmain, content: 価格涨到20.650
2
3
void onPush_UpdatePriceReminder(FTAPI_Conn client, int nSerialNo, QotUpdatePriceReminder.Response rsp);
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
- Example
public class QotDemo implements FTSPI_Qot, FTSPI_Conn {
FTAPI_Conn_Qot qot = new FTAPI_Conn_Qot();
public QotDemo() {
qot.setClientInfo("javaclient", 1); //クライアント情報の設定
qot.setConnSpi(this); //接続コールバックの設定
qot.setQotSpi(this); //取引コールバックの設定
}
public void start() {
qot.initConnect("127.0.0.1", (short)11111, false);
}
@Override
public void onInitConnect(FTAPI_Conn client, long errCode, String desc)
{
System.out.printf("Qot onInitConnect: ret=%b desc=%s connID=%d\n", errCode, desc, client.getConnectID());
if (errCode != 0)
return;
}
@Override
public void onDisconnect(FTAPI_Conn client, long errCode) {
System.out.printf("Qot onDisConnect: %d\n", errCode);
}
@Override
public void onPush_UpdatePriceReminder(FTAPI_Conn client, QotUpdatePriceReminder.Response rsp) {
if (rsp.getRetType() != 0) {
System.out.printf("QotUpdatePriceReminder failed: %s\n", rsp.getRetMsg());
}
else {
try {
String json = JsonFormat.printer().print(rsp);
System.out.printf("Receive QotUpdatePriceReminder: %s\n", json);
} catch (InvalidProtocolBufferException e) {
e.printStackTrace();
}
}
}
public static void main(String[] args) {
FTAPI.init();
QotDemo qot = new QotDemo();
qot.start();
while (true) {
try {
Thread.sleep(1000 * 600);
} catch (InterruptedException exc) {
}
}
}
}
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
- Output
Receive QotUpdatePriceReminder: {
"retType": 0,
"s2c": {
"security": {
"market": 1,
"code": "00700"
},
"price": 604,
"changeRate": 0.499,
"marketStatus": 1,
"content": "価格涨到604.000",
"note": "",
"key": "162321935858611601",
"type": 1,
"setValue": 604,
"curValue": 604
}
}
Receive QotUpdatePriceReminder: {
"retType": 0,
"s2c": {
"security": {
"market": 1,
"code": "00700"
},
"price": 603.5,
"changeRate": 0.415,
"marketStatus": 1,
"content": "価格跌到603.990",
"note": "",
"key": "162320791658522901",
"type": 2,
"setValue": 603.99,
"curValue": 603.5
}
}
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
virtual void OnPush_UpdatePriceReminder(const Qot_UpdatePriceReminder::Response &stRsp) = 0;
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
- Example
class Program : public FTSPI_Qot, public FTSPI_Trd, public FTSPI_Conn
{
public:
Program() {
m_pQotApi = FTAPI::CreateQotApi();
m_pQotApi->RegisterQotSpi(this);
m_pQotApi->RegisterConnSpi(this);
}
~Program() {
if (m_pQotApi != nullptr)
{
m_pQotApi->UnregisterQotSpi();
m_pQotApi->UnregisterConnSpi();
FTAPI::ReleaseQotApi(m_pQotApi);
m_pQotApi = nullptr;
}
}
void Start() {
m_pQotApi->InitConnect("127.0.0.1", 11111, false);
}
virtual void OnInitConnect(FTAPI_Conn* pConn, Futu::i64_t nErrCode, const char* strDesc) {
cout << "connect" << endl;
}
virtual void OnPush_UpdatePriceReminder(const Qot_UpdatePriceReminder::Response &stRsp) {
cout << "OnPush_UpdatePriceReminder: " << endl;
// 内部構造を解析して出力
// ProtoBufToBodyData と UTF8ToLocal 関数の定義は Sample の tool.h ファイルを参照
string resp_str;
ProtoBufToBodyData(stRsp, resp_str);
cout << UTF8ToLocal(resp_str) << endl;
}
protected:
FTAPI_Qot *m_pQotApi;
};
int32_t main(int32_t argc, char** argv)
{
FTAPI::Init();
{
Program program;
program.Start();
getchar();
}
protobuf::ShutdownProtobufLibrary();
FTAPI::UnInit();
return 0;
}
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
- Output
connect
OnPush_UpdatePriceReminder:
{
"retType": 0,
"s2c": {
"security": {
"market": 1,
"code": "00700"
},
"price": 604,
"changeRate": 0.499,
"marketStatus": 1,
"content": "価格涨到604.000",
"note": "",
"key": "162321935858611601",
"type": 1,
"setValue": 604,
"curValue": 604
}
}
OnPush_UpdatePriceReminder:
{
"retType": 0,
"s2c": {
"security": {
"market": 1,
"code": "00700"
},
"price": 603.5,
"changeRate": 0.415,
"marketStatus": 1,
"content": "価格跌到603.990",
"note": "",
"key": "162320791658522901",
"type": 2,
"setValue": 603.99,
"curValue": 603.5
}
}
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
OnPush(cmd,res)
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
- API 呼び出し結果,構造は~を参照: RetType
- Example
import ftWebsocket from "futu-api";
import { ftCmdID } from "futu-api";
import { Common, Qot_Common, Trd_Common } from "futu-api/proto";
import beautify from "js-beautify";
function QotUpdatePriceReminder(){
const { RetType } = Common
let [addr, port, enable_ssl, key] = ["127.0.0.1", 33333, false, 'ec16fde057a2e7a0'];
let websocket = new ftWebsocket();
// 既存の到達価格アラート設定が必要
websocket.onPush = (cmd, res)=>{
if(ftCmdID.QotUpdatePriceReminder.cmd == cmd){ // 到達価格アラートプッシュの処理ロジック
let { retType, s2c } = res
if(retType == RetType.RetType_Succeed){
let data = beautify(JSON.stringify(s2c), {
indent_size: 2,
space_in_empty_paren: true,
});
console.log("PriceReminderTest:");
console.log(data);
} else {
console.log("PriceReminderTest: error")
}
}
};
websocket.start(addr, port, enable_ssl, key);
setTimeout(()=>{
websocket.stop();
console.log("stop");
}, 3600 * 1000); // OpenD のプッシュ受信を3600秒間継続し、3600秒後に切断
}
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
- Output
PriceReminderTest:
{
"security": {
"market": 1,
"code": "00700"
},
"price": 482.8,
"changeRate": 1.004,
"marketStatus": 1,
"content": "Daily rises more than 1.000%",
"note": "",
"key": "163126377342664201",
"type": 3,
"setValue": 1,
"curValue": 1.004
}
stop
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
ご注意
- このAPIは継続的にプッシュデータを取得する機能を提供します。一括でリアルタイムデータを取得する場合は 到達価格アラート取得 APIをご利用ください
- リアルタイムデータの取得とリアルタイムデータコールバックの違いについては、 如何から登録 API で取得してくださいリアルタイム相場情報?
- Python
- Proto
- C#
- Java
- C++
- JavaScript
on_recv_rsp(self, rsp_pb)
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
リアルタイム到達価格アラート通知プッシュの受信時にこの関数がコールバックされます。派生クラスで on_recv_rsp をオーバーライドしてください。パラメータ
パラメータ 型 説明 rsp_pb Qot_UpdatePriceReminder_pb2.Response 派生クラスでは直接処理不要
戻り値
パラメータ 型 説明 ret RET_CODE API呼び出し結果 data dict 当 ret == RET_OK,返す到達価格アラート str ret != RET_OK の場合、エラーの説明を返す - 到達価格アラート
フィールド タイプ 説明 code str 銘柄コード name str 銘柄名 price float 現在の価格 change_rate str 現在の騰落率 market_status PriceReminderMarketStatus トリガーの時間帯 content str 到達価格アラート文字内容 note str 備考 最大20文字まで対応key int 到達価格アラート識別子 reminder_type PriceReminderType 到達価格アラートのタイプ set_value float 用户設定したアラート値 cur_value float アラートトリガー時の値
- 到達価格アラート
Example
import time
from moomoo import *
class PriceReminderTest(PriceReminderHandlerBase):
def on_recv_rsp(self, rsp_pb):
ret_code, content = super(PriceReminderTest,self).on_recv_rsp(rsp_pb)
if ret_code != RET_OK:
print("PriceReminderTest: error, msg: %s" % content)
return RET_ERROR, content
print("PriceReminderTest ", content) # PriceReminderTest 独自の処理ロジック
return RET_OK, content
quote_ctx = OpenQuoteContext(host='127.0.0.1', port=11111)
handler = PriceReminderTest()
quote_ctx.set_handler(handler) # 到達価格アラート通知コールバックを設定
time.sleep(15) # スクリプトが OpenD のプッシュを受信する時間を15秒に設定
quote_ctx.close() # 接続をクローズすると、OpenD は1分後に対応銘柄の登録を自動解除
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
- Output
PriceReminderTest {'code': 'US.AAPL', 'name': '苹果', 'price': 185.750, 'change_rate': 0.11, 'market_status': 'US_PRE', 'content': '買一価高于185.500', 'note': '', 'key': 1744022257052794489, 'reminder_type': 'BID_PRICE_UP', 'set_value': 185.500, 'cur_value': 185.750}
# Qot_UpdatePriceReminder.proto
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
プロトコル ID
3019
virtual void OnReply_UpdatePriceReminder(MMAPI_Conn client, uint nSerialNo, QotUpdatePriceReminder.Response rsp);
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
- Example
public class Program : MMSPI_Qot, MMSPI_Conn {
MMAPI_Qot qot = new MMAPI_Qot();
public Program() {
qot.SetClientInfo("csharp", 1); //クライアント情報の設定
qot.SetConnCallback(this); //接続コールバックの設定
qot.SetQotCallback(this); //取引コールバックの設定
}
public void Start() {
qot.InitConnect("127.0.0.1", (ushort)11111, false);
}
public void OnInitConnect(MMAPI_Conn client, long errCode, String desc)
{
Console.Write("Qot onInitConnect: ret={0} desc={1} connID={2}\n", errCode, desc, client.GetConnectID());
if (errCode != 0)
return;
}
public void OnDisconnect(MMAPI_Conn client, long errCode) {
Console.Write("Qot onDisConnect: {0}\n", errCode);
}
public void OnReply_UpdatePriceReminder(MMAPI_Conn client, uint nSerialNo, QotUpdatePriceReminder.Response rsp)
{
Console.Write("Reply: QotUpdatePriceReminder: {0}\n", nSerialNo);
Console.Write("code: {0}, content: {1}\n", rsp.S2C.Security.Code, rsp.S2C.Content);
}
public static void Main(String[] args) {
MMAPI.Init();
Program qot = new Program();
qot.Start();
while (true)
Thread.Sleep(1000 * 600);
}
}
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
42
- Output
Qot onInitConnect: ret=0 desc= connID=6826796032557005979
Reply: QotUpdatePriceReminder: 4
code: VXmain, content: 価格涨到20.650
2
3
void onPush_UpdatePriceReminder(MMAPI_Conn client, int nSerialNo, QotUpdatePriceReminder.Response rsp);
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
- Example
public class QotDemo implements MMSPI_Qot, MMSPI_Conn {
MMAPI_Conn_Qot qot = new MMAPI_Conn_Qot();
public QotDemo() {
qot.setClientInfo("javaclient", 1); //クライアント情報の設定
qot.setConnSpi(this); //接続コールバックの設定
qot.setQotSpi(this); //取引コールバックの設定
}
public void start() {
qot.initConnect("127.0.0.1", (short)11111, false);
}
@Override
public void onInitConnect(MMAPI_Conn client, long errCode, String desc)
{
System.out.printf("Qot onInitConnect: ret=%b desc=%s connID=%d\n", errCode, desc, client.getConnectID());
if (errCode != 0)
return;
}
@Override
public void onDisconnect(MMAPI_Conn client, long errCode) {
System.out.printf("Qot onDisConnect: %d\n", errCode);
}
@Override
public void onPush_UpdatePriceReminder(MMAPI_Conn client, QotUpdatePriceReminder.Response rsp) {
if (rsp.getRetType() != 0) {
System.out.printf("QotUpdatePriceReminder failed: %s\n", rsp.getRetMsg());
}
else {
try {
String json = JsonFormat.printer().print(rsp);
System.out.printf("Receive QotUpdatePriceReminder: %s\n", json);
} catch (InvalidProtocolBufferException e) {
e.printStackTrace();
}
}
}
public static void main(String[] args) {
MMAPI.init();
QotDemo qot = new QotDemo();
qot.start();
while (true) {
try {
Thread.sleep(1000 * 600);
} catch (InterruptedException exc) {
}
}
}
}
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
- Output
Receive QotUpdatePriceReminder: {
"retType": 0,
"s2c": {
"security": {
"market": 1,
"code": "00700"
},
"price": 604,
"changeRate": 0.499,
"marketStatus": 1,
"content": "価格涨到604.000",
"note": "",
"key": "162321935858611601",
"type": 1,
"setValue": 604,
"curValue": 604
}
}
Receive QotUpdatePriceReminder: {
"retType": 0,
"s2c": {
"security": {
"market": 1,
"code": "00700"
},
"price": 603.5,
"changeRate": 0.415,
"marketStatus": 1,
"content": "価格跌到603.990",
"note": "",
"key": "162320791658522901",
"type": 2,
"setValue": 603.99,
"curValue": 603.5
}
}
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
virtual void OnPush_UpdatePriceReminder(const Qot_UpdatePriceReminder::Response &stRsp) = 0;
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
- Example
class Program : public MMSPI_Qot, public MMSPI_Trd, public MMSPI_Conn
{
public:
Program() {
m_pQotApi = MMAPI::CreateQotApi();
m_pQotApi->RegisterQotSpi(this);
m_pQotApi->RegisterConnSpi(this);
}
~Program() {
if (m_pQotApi != nullptr)
{
m_pQotApi->UnregisterQotSpi();
m_pQotApi->UnregisterConnSpi();
MMAPI::ReleaseQotApi(m_pQotApi);
m_pQotApi = nullptr;
}
}
void Start() {
m_pQotApi->InitConnect("127.0.0.1", 11111, false);
}
virtual void OnInitConnect(MMAPI_Conn* pConn, moomoo::i64_t nErrCode, const char* strDesc) {
cout << "connect" << endl;
}
virtual void OnPush_UpdatePriceReminder(const Qot_UpdatePriceReminder::Response &stRsp) {
cout << "OnPush_UpdatePriceReminder: " << endl;
// 内部構造を解析して出力
// ProtoBufToBodyData と UTF8ToLocal 関数の定義は Sample の tool.h ファイルを参照
string resp_str;
ProtoBufToBodyData(stRsp, resp_str);
cout << UTF8ToLocal(resp_str) << endl;
}
protected:
MMAPI_Qot *m_pQotApi;
};
int32_t main(int32_t argc, char** argv)
{
MMAPI::Init();
{
Program program;
program.Start();
getchar();
}
protobuf::ShutdownProtobufLibrary();
MMAPI::UnInit();
return 0;
}
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
- Output
connect
OnPush_UpdatePriceReminder:
{
"retType": 0,
"s2c": {
"security": {
"market": 1,
"code": "00700"
},
"price": 604,
"changeRate": 0.499,
"marketStatus": 1,
"content": "価格涨到604.000",
"note": "",
"key": "162321935858611601",
"type": 1,
"setValue": 604,
"curValue": 604
}
}
OnPush_UpdatePriceReminder:
{
"retType": 0,
"s2c": {
"security": {
"market": 1,
"code": "00700"
},
"price": 603.5,
"changeRate": 0.415,
"marketStatus": 1,
"content": "価格跌到603.990",
"note": "",
"key": "162320791658522901",
"type": 2,
"setValue": 603.99,
"curValue": 603.5
}
}
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
OnPush(cmd,res)
概要
到達価格アラート通知コールバック。設定済み到達価格アラートの通知プッシュを非同期処理します。
パラメータ
enum MarketStatus
{
MarketStatus_Unknow = 0;
MarketStatus_Open = 1; // 立会時間中
MarketStatus_USPre = 2; // 米国株プレマーケット
MarketStatus_USAfter = 3; // 米国株アフターマーケット
MarketStatus_USOverNight = 4; // 米国株夜間取引
}
message S2C
{
required Qot_Common.Security security = 1; //株式
optional string name = 11; // 銘柄名
required double price = 2; //価格
required double changeRate = 3; //当日騰落率
required int32 marketStatus = 4; //Qot_Common::MarketStatus 市場ステータス
required string content = 5; //内容
required string note = 6; //備考は最大20文字まで対応
optional int64 key = 7; //到達価格アラートの識別子
optional int32 type = 8; //Qot_Common::PriceReminderType, アラート頻度タイプ
optional double setValue = 9; //設定したアラート値
optional double curValue = 10; //設定したアラートタイプのトリガー時の現在値
}
message Response
{
required int32 retType = 1 [default = -400]; //RetType、戻り値
optional string retMsg = 2;
optional int32 errCode = 3;
optional S2C s2c = 4;
}
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
- 株式構造は~を参照: Security
- 提醒タイプ枚举参见 PriceReminderType
- API 呼び出し結果,構造は~を参照: RetType
- API 呼び出し結果,構造は~を参照: RetType
- Example
import mmWebsocket from "moomoo-api";
import { mmCmdID } from "moomoo-api";
import { Common, Qot_Common, Trd_Common } from "moomoo-api/proto";
import beautify from "js-beautify";
function QotUpdatePriceReminder(){
const { RetType } = Common
let [addr, port, enable_ssl, key] = ["127.0.0.1", 33333, false, 'ec16fde057a2e7a0'];
let websocket = new mmWebsocket();
// 既存の到達価格アラート設定が必要
websocket.onPush = (cmd, res)=>{
if(ftCmdID.QotUpdatePriceReminder.cmd == cmd){ // 到達価格アラートプッシュの処理ロジック
let { retType, s2c } = res
if(retType == RetType.RetType_Succeed){
let data = beautify(JSON.stringify(s2c), {
indent_size: 2,
space_in_empty_paren: true,
});
console.log("PriceReminderTest:");
console.log(data);
} else {
console.log("PriceReminderTest: error")
}
}
};
websocket.start(addr, port, enable_ssl, key);
setTimeout(()=>{
websocket.stop();
console.log("stop");
}, 3600 * 1000); // FOpenD のプッシュ受信を3600秒間継続し、3600秒後に切断
}
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
- Output
PriceReminderTest:
{
"security": {
"market": 1,
"code": "00700"
},
"price": 482.8,
"changeRate": 1.004,
"marketStatus": 1,
"content": "Daily rises more than 1.000%",
"note": "",
"key": "163126377342664201",
"type": 3,
"setValue": 1,
"curValue": 1.004
}
stop
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
ご注意
- このAPIは継続的にプッシュデータを取得する機能を提供します。一括でリアルタイムデータを取得する場合は 到達価格アラート取得 APIをご利用ください
- リアルタイムデータの取得とリアルタイムデータコールバックの違いについては、 如何から登録 API で取得してくださいリアルタイム相場情報?
← ウォッチリストの変更 相場情報の定義 →