OrderDelete()の使用方法
MQL4 (MT4)のOrderDelete()の使い方をChatGPTに確認しました。
使用GPTs:EA Creator
MT4 MQL4のOrderDeleteの利用方法を実装例を教えて下さい。補足で気を付ける点なども教えて下さい。
回答
OrderDelete
関数は、MetaTrader 4 (MT4) プラットフォームで保留中の注文(未決済の注文)を削除するために使用されるMQL4言語の関数です。この関数を使って、特定の条件が満たされた場合に自動的に保留中の注文をキャンセルするロジックを実装することが可能です。
OrderDelete関数の基本形式
bool OrderDelete(
int ticket, // 注文チケット番号
color arrow_color // チャート上の矢印の色
);
使用例
以下は、特定の保留中の注文を削除する簡単な例です。この例では、最初に開かれている保留中の注文の中から指定した条件に合致する注文を検索し、見つかった注文を削除します。
void DeleteFirstPendingOrder()
{
for(int i = 0; i < OrdersTotal(); i++)
{
if(OrderSelect(i, SELECT_BY_POS) && OrderType() > OP_SELL) // 保留中の注文を検索(OP_BUYLIMIT, OP_SELLLIMIT, OP_BUYSTOP, OP_SELLSTOP)
{
if(OrderDelete(OrderTicket(), clrYellow)) // 注文を削除
{
Print("Order deleted successfully. Ticket: ", OrderTicket());
}
else
{
Print("Failed to delete order. Error: ", GetLastError());
}
break; // 最初の保留中の注文を削除したらループを抜ける
}
}
}
注意点
- エラーハンドリング:
OrderDelete
関数がfalse
を返した場合、GetLastError
関数を使用してエラーコードを取得し、エラーの原因を特定することが重要です。 - 実行前の注文選択: 注文を削除する前に、
OrderSelect
関数を使用して操作対象の注文を正しく選択する必要があります。 - 保留中の注文の種類:
OrderType
関数を使って注文の種類をチェックし、保留中の注文(OP_BUYLIMIT, OP_SELLLIMIT, OP_BUYSTOP, OP_SELLSTOP)のみを対象としていることを確認します。既に開かれている取引(市場注文)はOrderClose
関数を使って閉じる必要があります。 - 保留中注文の削除理由: 注文を削除する前に、その理由を明確にしておくことが重要です。例えば、市場状況が変化したため、または特定の戦略に基づいて注文がもはや有効でないと判断された場合などです。
OrderDelete
関数を使用する際には、これらのポイントに注意しながら、自分の取引戦略に合わせたロジックの実装を行ってください。
MQL4リファレンス
式な仕様は”MQL4 Reference“をご確認下さい。上記内容を確認しておくとより分かりやすいかと思います。
リンク:https://docs.mql4.com/trading/orderdelete
他のトレード関数の使用方法
以下のそれぞれのリンク先で確認していますので、ご参照ください。
関数名 | 概要 |
---|---|
OrderClose | 指定されたチケット番号、ロット数、クローズ価格、スリッページを指定して特定の注文を閉じるために使用されます。成功した場合、真を返します。 |
OrderCloseBy | 2つの相反する注文を相殺するために使用され、一方の注文を閉じ、もう一方には相当する利益または損失が記録されます。 |
OrderClosePrice | 最後に閉じられた注文のクローズ価格を返します。注文が選択されている必要があります。 |
OrderCloseTime | 注文が閉じられた正確な日時を返します。注文が閉じられていない場合は、ゼロを返します。 |
OrderComment | 注文に関連付けられたコメントを返します。 |
OrderCommission | 注文にかかるコミッションの金額を返します。 |
OrderDelete | 指定されたチケット番号の保留中の注文を削除します。成功した場合、真を返します。 |
OrderExpiration | 保留注文の有効期限を日時形式で返します。有効期限が設定されていない場合は、ゼロを返します。 |
OrderLots | 注文のロット数を返します。 |
OrderMagicNumber | 注文に割り当てられたマジックナンバーを返します。これは注文を識別するためにEAによって使用される数値です。 |
OrderModify | 既存の注文のパラメータ(価格、ストップロス、テイクプロフィット、有効期限等)を変更します。成功した場合、真を返します。 |
OrderOpenPrice | 注文が開かれた価格を返します。 |
OrderOpenTime | 注文が開かれた正確な日時を返します。 |
OrderProfit | 選択された注文の詳細情報をエキスパートログに出力します。 |
OrderProfit | 注文から得られた利益または損失を返します。 |
OrderSelect | 指定されたチケット番号の注文を選択するか、全注文の中から特定の注文を選択します。成功した場合、真を返します。 |
OrderSend | 新しい注文を送信します。注文のタイプ、量、価格、ストップロス、テイクプロフィット等を指定できます。成功した場合、注文のチケット番号を返します。 |
OrdersHistoryTotal | アカウントの取引履歴に含まれる注文の総数を返します。これには閉じられた注文とキャンセルされた注文が含まれます。 |
OrderStopLoss | 注文のストップロスレベルを返します。 |
OrdersTotal | 現在開いている注文の総数を返します。 |
OrderSwap | 注文にかかるスワップ料金を返します。 |
OrderSymbol | 注文が関連する通貨ペアを返します。 |
OrderTakeProfit | 注文のテイクプロフィットレベルを返します。 |
OrderTicket | 注文のユニークなチケット番号を返します。 |
OrderType | 注文のタイプ(買い、売り、買い停止、売り停止、買いリミット、売りリミット)を表す整数値を返します。 |
コメント