1. StringToInteger関数の概要と実務での活用法
StringToInteger関数は、MQL5で「文字列(string型)」を「整数(long型)」に変換するための関数です。
一見地味な関数に思えるかもしれませんが、実務レベルのEA(エキスパートアドバイザー)やインジケーター開発においては非常に重要な役割を担います。例えば、以下のような場面で多用されます。
- GUI(操作パネル)からの入力: チャート上に配置したエディットボックス(入力欄)に入力された数値は、プログラム内部では「文字列」として認識されます。これをマジックナンバーやロット計算の整数として扱うために変換が必要です。
- 外部ファイル(CSV等)の読み込み: 設定ファイルや外部データから読み取った値はすべて文字列です。これらを計算ロジックに組み込む際に必須となります。
- グローバル変数の操作: ターミナル間で共有するグローバル変数を文字列で管理している場合、数値として復元する際に使用します。
初心者の方がつまずきやすいポイントは、「見た目が数字の文字列」と「計算ができる数値」を混同してしまうことです。"123"は文字の羅列であり、これに1を加算しても124にはなりません。計算を行う前に必ずこの関数で数値型にキャスト(変換)する必要があります。
2. 構文と戻り値
StringToInteger関数の基本的な構文は以下の通りです。
long StringToInteger(
string value // 変換対象の文字列
);
パラメーター
- value: 整数に変換したい文字列を指定します。
戻り値
- long型: 変換された整数値を返します。MQL5の
long型は64ビット整数であるため、非常に大きな数値(-9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807)まで扱うことが可能です。
もし、指定した文字列が数値として解釈できない場合(例: "abc"など)は 0 を返します。
3. 具体的な使い方・実践サンプルコード
実際のEA開発を想定し、チャート上の入力ボックスからマジックナンバーを取得し、それを数値に変換して注文に使用する例を見てみましょう。
//+------------------------------------------------------------------+
//| ユーザー入力された文字列をマジックナンバーとして処理するサンプル |
//+------------------------------------------------------------------+
void OnStart()
{
// 例:GUIのエディットボックスから取得したと仮定した文字列
string inputString = "88822233";
// 文字列を整数(long)に変換
long magicNumber = StringToInteger(inputString);
// 変換後の値を確認
if(magicNumber > 0)
{
Print("変換成功: マジックナンバー = ", magicNumber);
// ここで実際のトレード処理などに利用する
// Trade.SetExpertMagicNumber(magicNumber);
}
else
{
// 文字列が数字でない場合や"0"の場合
Print("警告: 有効な数値が入力されていません。");
}
// 小数点を含む文字列の場合の挙動確認
string doubleString = "123.45";
long convertedInt = StringToInteger(doubleString);
// 結果は「123」となる(小数点以下は切り捨てられる)
Print("小数点を含む文字列を変換: ", convertedInt);
}
4. 使用上の注意点とよくあるエラー
開発時に注意すべき点は、「変換不能な文字列」に対する挙動と「型」の不一致です。
-
非数値文字列の入力:
StringToInteger("Trading")のように、数字以外の文字列を変換しようとすると0が返されます。このとき、入力された値が本当に「0」だったのか、エラーで「0」になったのかを判別するには、事前に文字列が数値形式かどうかをチェックするロジックが必要です。 -
小数点以下の切り捨て:
StringToInteger("10.5")を実行すると、戻り値は10になります。四捨五入ではなく、小数点以下は単純に破棄されます。ロット数(0.01など)を扱いたい場合は、この関数ではなくStringToDoubleを使用してください。 -
全角数字の非対応:
日本語環境でやりがちなミスとして、全角の「123」を入力してしまうケースがあります。これは数値として認識されず0になるため、ユーザー入力部では半角入力を徹底させるか、プログラム側で全角半角変換を挟む必要があります。
5. 【重要】自動売買における約定スピードと環境の罠
アルゴリズムのコードが完璧であっても、それを実行するインフラが貧弱であれば、勝てるロジックも損失を生む道具に成り下がります。特に自宅のPCや一般的な光回線での運用は、FXトレードにおいて致命的なリスクを伴います。家庭用ネットワークは数ミリ秒から数百ミリ秒のレイテンシ(遅延)が常態化しており、この「一瞬の遅れ」が注文価格の滑り(スリッページ)を引き起こし、バックテスト通りのパフォーマンスを著しく阻害します。
機関投資家やプロのクオンツエンジニアが勝てるのは、ブローカーのサーバーと同じデータセンター内、あるいは極めて近い距離にある専用のVPS(仮想専用サーバー)を利用し、物理的な距離による遅延を極限まで排除しているからです。24時間365日の安定稼働はもちろん、マイクロ秒単位の約定スピードが求められる自動売買の世界において、専用VPSの導入は「オプション」ではなく「必須の装備」であると断言できます。環境構築への投資を惜しむことは、トレードにおける最大の戦略的ミスと言えるでしょう。
💡 この記事の内容を実運用で活かすには?
この記事の内容を実運用で活かすには、正しい環境が必要です。
特にVPSを使わないと、このロジックは再現できません。

コメント