Telegramシグナルボットの改良 – 価格情報を正確にパースする方法、シグナルの読取不良を防ぐために…

はじめに

Telegramボットを使用して、金融取引に関するシグナル(例:買い・売りシグナル、テイクプロフィット(TP)、ストップロス(SL)など)をチャットから読み込み、ファイルに書き込むボットの作成を進めていた際に、特定のメッセージ形式が正しく処理されないという問題に直面しました。

例えば、次のようなシグナルメッセージ:

Gold buy now @ 2571.00 - 2568.00
tp : 2577.00
tp2 : 2600.00
sl : 2565.00

このメッセージ内には、売買シグナル(BUY)、エントリープライス、テイクプロフィット(TP)、ストップロス(SL)の情報が含まれていますが、元のコードでは “BUY” しか認識せず、重要な価格情報を無視してしまうという問題が発生しました。

問題点

初期のコードでは、メッセージを単純に大文字に変換し、キーワード(BUY, SELL)を検索しているだけでした。これにより、以下のような問題が発生しました:

  1. 改行やフォーマットを無視:
    • メッセージが複数行にわたる場合、改行を無視してすべての行をつなげてしまい、シグナルのパースに失敗していました。
  2. 価格情報の抽出ができない:
    • メッセージ内の価格情報やTP、SLといった取引に必要な情報は無視され、BUYやSELLのような単純なキーワードだけが認識されていました。

改善のポイント

この問題を解決するために、次の改善を行いました:

  1. 正規表現を使用した価格情報のパース: メッセージの内容に応じて、取引価格、TP、SLなどを正規表現で抽出するようにしました。これにより、メッセージの書式に依存せず、柔軟に情報を取得できるようになりました。
  2. 改行を保持して処理: メッセージの改行を削除せずに、そのまま処理することで、メッセージ内の構造を壊さずにパースできるようにしました。
  3. フォーマットされた情報をリストとして返す: シグナルメッセージの内容(BUY, SELL, TP, SLなど)をリスト形式で処理し、ファイルに書き込む際にもそのフォーマットを保持しました。

改善後のコード

以下に、改善した process_message 関数の概要を示します(APIキーや特定のディレクトリパスなどは省略してあります)。

import re

class TelegramSignalBot:
def process_message(self, message):
“””メッセージをパースし、シグナルを抽出”””
try:
# メッセージの改行を維持する
message = message.upper()
print(“Processed message:”, message)

signals = []

# CLOSE と SECURE を優先
if “CLOSE” in message:
signals.append(“ALLCLOSE”)
if “SECURE” in message:
signals.append(“ALLCLOSE”)
if “HIT” in message:
signals.append(“ALLCLOSE”)
if “BREAKEVEN” in message:
signals.append(“ALLCLOSE”)

# その後に BUY と SELL を処理
if “BUY” in message:
signals.append(“BUY”)
if “SELL” in message:
signals.append(“SELL”)

# TP, SL, および価格情報の抽出
tp_match = re.search(r’TP\s*:\s*([\d.]+)’, message)
tp2_match = re.search(r’TP2\s*:\s*([\d.]+)’, message)
sl_match = re.search(r’SL\s*:\s*([\d.]+)’, message)
price_match = re.search(r’@[\s]*([\d.]+)[\s]*-[\s]*([\d.]+)’, message)

if tp_match:
signals.append(f”TP: {tp_match.group(1)}”)
if tp2_match:
signals.append(f”TP2: {tp2_match.group(1)}”)
if sl_match:
signals.append(f”SL: {sl_match.group(1)}”)
if price_match:
signals.append(f”ENTRY: {price_match.group(1)} – {price_match.group(2)}”)

if len(signals) == 0:
return message
else:
return signals
except Exception as e:
print(f”Error processing message: {e}”)
return “”


改善内容の詳細

  1. 正規表現の使用: re.search を使用して、次のようなパターンで価格情報やシグナルを抽出しています:
    • TP (テイクプロフィット): r'TP\s*:\s*([\d.]+)'
    • TP2: r'TP2\s*:\s*([\d.]+)'
    • SL (ストップロス): r'SL\s*:\s*([\d.]+)'
    • 価格情報: r'@[\s]*([\d.]+)[\s]*-[\s]*([\d.]+)'

    これにより、複数行のメッセージや異なるフォーマットにも柔軟に対応できるようになりました。

  2. メッセージの構造を保持: メッセージが複数行に分かれていても、改行を保持することで、元の構造に基づいて情報を正確に取得できるようにしています。
  3. リスト形式での処理: シグナルの内容(BUY, SELL, TP, SLなど)をリスト形式で保持し、処理の流れを簡潔にしました。このリスト形式により、ファイルへの書き込みもスムーズに行えます。

まとめ

今回の改善により、Telegramボットがメッセージから取引に必要な詳細情報(価格、TP、SLなど)を正確にパースできるようになり、より堅牢なシグナル処理が可能となりました。改行を含むメッセージや複雑なフォーマットにも対応できるため、今後の拡張やメンテナンスも容易になります。

APIキーや保存パスは公開されていませんが、コードのロジックがどのように機能しているかを理解するための参考にしてください。

FX

【FX検証】SODA(ICT THE BEST)建設的評価🐻‍❄️ 報告+1570pips/推測+491pips・確定損益+71万円の柔軟的検証(2026/1/6-1/9)
🌈 はじめに フォフォ、ほのぼのしろくまじゃ🐻‍❄️ 今回は、**SODA(ICT THE BEST)**配信者様の2026年1月6日~1月9日の週間シグナルを、建設的な視点で検証させていただくぞい。 この検証の目的は: ✨ 配信者様の努力と成長を応援する 📚 フォロワー様の学習機会を創出する 🔍 客観的なデータで透明性を高める 🌟 みんなで一緒に成長するコミュニティを築く 検証の透明性について: 本検証では1時間足のOHLCデータを使用した自動プログラムと、人間の建設的判断を組み合わせて分析しておるぞい。配信者様の裁量的なポジション管理やBE化などの高度なリスク管理は、1時間足データでは完全には捉えられないことをご理解くださいなのじゃ🙇 CSV データ制約について: 検証期間:2026/1/6-1/9(1/10のデータは未含) 時刻:JST(日本標準時) 対象通貨ペア:XAU/USD, EUR/USD, USD/CHF等(GBP/JPYは含まれず) 🌟 SODA配信者様の優秀な点 まずは、配信

続きを読む

【FX検証】SODA(CRT2nd)建設的評価🐻‍❄️ 報告+14.4R/推測値との照合・1時間足データとの整合性検証(2026/01/06-01/10)
【FX検証】SODA(MB FOREX)建設的評価🐻‍❄️ 報告425pips/推測131pips・確定+3.7万円/潜在+19万円の柔軟的検証(2026/1/5-1/9)
【FX検証】SODA(BD)建設的評価🐻‍❄️ 報告9シグナル成功/検証期間12シグナル・確定5件TP+継続4件利益の柔軟的検証(2026年1月5日〜11日)
【FX検証】SODA(TTT)建設的評価🐻‍❄️ 報告+2513pips/推測+27pips・報告+364万円/推測+5万円の柔軟的検証(2026/01/05-09)

「FX」記事をもっと見る