ข้ามไปที่เนื้อหา

คำนวณกำไรและขาดทุน

การคำนวณ P&L เป็นกรณีการใช้งานที่สำคัญที่ต้องถูกนำไปใช้โดยเกือบทุกแอปพลิเคชันและบริการของ cTrader Open API

การคำนวณ P&L ด้วยตนเองเป็นกระบวนการที่ยาก เนื่องจากการคำนวณจำเป็นต้องคำนึงถึงขนาดตำแหน่งและการแปลงที่อาจเกิดขึ้นระหว่างสินทรัพย์อ้างอิงของสัญลักษณ์ที่ซื้อหรือขายและสกุลเงินฝากของบัญชี

โชคดีที่คุณสามารถขอให้แบ็กเอนด์ของ cTrader คำนวณ P&L ให้คุณได้โดยการส่ง ข้อความ ProtoOAGetPositionUnrealizedPnLReq คุณควรได้รับ ข้อความ ProtoOAGetPositionUnrealizedPnLRes ที่มี ข้อความโมเดล ProtoOAPositionUnrealizedPnL ในหนึ่งในฟิลด์ของมัน

หมายเหตุ

ProtoOAGetPositionUnrealizedPnLRes มีข้อมูลเกี่ยวกับ P&L ของทุกตำแหน่งที่เปิดอยู่ในปัจจุบันของบัญชีที่มี ctidTraderAccountId ที่ระบุในฟิลด์ positionUnrealizedPnL ที่ซ้ำกัน

ข้อจำกัดอัตรา

การขอ P&L เป็นคำขอที่ไม่ใช่ประวัติศาสตร์ ซึ่งหมายความว่าคุณสามารถทำคำขอดังกล่าวได้สูงสุด 50 ครั้งต่อวินาที เราขอแนะนำให้รีเฟรช P&L ทุกสองถึงสามวินาทีเพื่อไม่ให้มีความเสี่ยงที่จะเกินข้อจำกัดอัตรา

เรียนรู้เพิ่มเติมเกี่ยวกับการส่งและรับข้อความในบทเรียนเกี่ยวกับ Protobuf และ JSON

เมื่อทำงานกับ Protobuf คุณสามารถใช้คลาสที่สร้างโดยคอมไพเลอร์สำหรับการซีเรียลไลเซชันและดีซีเรียลไลเซชันของข้อความเพื่อรับอัตรา P&L เมื่อทำงานกับ JSON คุณจะต้องสร้างคลาสดังกล่าวด้วยตัวเอง นี่คือตัวอย่างว่าคลาสเหล่านั้นอาจมีลักษณะอย่างไร

 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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
public abstract class OpenAPIModelMessageBase { }

public class PositionUnrealizedPnL : OpenAPIModelMessageBase
{
    public PositionUnrealizedPnL() { }
    public PositionUnrealizedPnL(int positionId, int grossUnrealizedPnL, int netUnrealizedPnL) 
    {
        this.PositionId = positionId;
        this.GrossUnrealizedPnL = grossUnrealizedPnL;
        this.NetUnrealizedPnL = netUnrealizedPnL;
    }

    public int PositionId { get; set; }
    public int GrossUnrealizedPnL { get; set; }
    public int NetUnrealizedPnL { get; set; }
}

public class GetPositionUnrealizedPnLReq : OpenAPIMessageBase
{
    public GetPositionUnrealizedPnLReq() { }
    public GetPositionUnrealizedPnLReq(int ctidTraderAccountId)
    {
        this.Payload = new GetPositionUnrealizedPnLReqPayload(ctidTraderAccountId);
        this.ClientMsgId = Guid.NewGuid().ToString();
    }

    public override int PayloadType => 2187;
    public GetPositionUnrealizedPnLReqPayload? Payload { get; set; }
}

public class GetPositionUnrealizedPnLReqPayload : OpenAPIMessagePayloadBase
{
    public GetPositionUnrealizedPnLReqPayload() { }
    public GetPositionUnrealizedPnLReqPayload(int ctidTraderAccountId)
    {
        this.CtidTraderAccountId = ctidTraderAccountId;
    }

    public int CtidTraderAccountId { get; set; } = 0;

}

public class GetPositionUnrealizedPnLRes : OpenAPIMessageBase 
{
    public GetPositionUnrealizedPnLRes() { }
    public GetPositionUnrealizedPnLRes(int ctidTraderAccountId, int moneyDigits, List<PositionUnrealizedPnL> positionUnrealizedPnL)
    {
        this.Payload = new GetPositionUnrealizedPnLResPayload(ctidTraderAccountId, moneyDigits, positionUnrealizedPnL);
        this.ClientMsgId = Guid.NewGuid().ToString();
    }

    public override int PayloadType => 2188;
    public GetPositionUnrealizedPnLResPayload? Payload { get; set; }

}

public class GetPositionUnrealizedPnLResPayload : OpenAPIMessagePayloadBase
{
    public GetPositionUnrealizedPnLResPayload() { }
    public GetPositionUnrealizedPnLResPayload(int ctidTraderAccountId, int moneyDigits, List<PositionUnrealizedPnL> positionUnrealizedPnL)
    {
        this.CtidTraderAccountId = ctidTraderAccountId;
        this.MoneyDigits = moneyDigits;
        this.PositionUnrealizedPnL = positionUnrealizedPnL;
    }

    public int CtidTraderAccountId { get; set; } = 0;
    public int MoneyDigits { get; set; } = 0;
    public List<PositionUnrealizedPnL> PositionUnrealizedPnL { get; set; } = new List<PositionUnrealizedPnL>();
}
 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
class OpenAPIModelMessage:
    def __init__(self):
        pass

class PositionUnrealizedPnL(OpenAPIModelMessage):
    def __init__(self, position_id, gross_unrealized_pnl, net_unrealized_pnl):
        self.position_id = position_id
        self.gross_unrealized_pnl = gross_unrealized_pnl
        self.net_unrealized_pnl = net_unrealized_pnl

class GetPositionUnrealizedPnLReq(OpenAPIMessage):
    def __init__(self, ctid_trader_account_id, client_msg_id = str(uuid.uuid4())):
        self.ctid_trader_account_id = ctid_trader_account_id
        self.payload_type = 2187
        self.client_msg_id = client_msg_id
        self.payload = {"ctidTraderAccountId": self.ctid_trader_account_id}

    def as_json_string(self):
        return json.dumps({"clientMsgId": self.client_msg_id, "payloadType": self.payload_type, "payload": self.payload})

    @staticmethod
    def from_json(json_dct):
        return GetPositionUnrealizedPnLReq(client_id=json_dct['payload']['clientId'], client_secret=json_dct['payload']['clientSecret'], client_msg_id=json_dct['clientMsgId'])

class GetPositionUnrealizedPnLRes(OpenAPIMessage):
    def __init__(self, ctid_trader_account_id, position_unrealized_pnl, money_digits, client_msg_id):
        self.ctid_trader_account_id = ctid_trader_account_id
        self.position_unrealized_pnl = position_unrealized_pnl
        self.money_digits = money_digits
        self.client_msg_id = client_msg_id

    def as_json_string(self):
        return json.dumps({"clientMsgId": self.client_msg_id, "payloadType": self.payload_type, "payload": self.payload})

    @staticmethod
    def from_json(json_dct):
        return GetPositionUnrealizedPnLRes(ctid_trader_account_id=json_dct['payload']['clientSecret'], position_unrealized_pnl=json_dct['payload']['positionUnrealizedPnL'], money_digits=json_dct['payload']['moneyDigits'], client_msg_id=['clientMsgId'])