はじめに
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)を検索しているだけでした。これにより、以下のような問題が発生しました:
- 改行やフォーマットを無視:
- メッセージが複数行にわたる場合、改行を無視してすべての行をつなげてしまい、シグナルのパースに失敗していました。
- 価格情報の抽出ができない:
- メッセージ内の価格情報やTP、SLといった取引に必要な情報は無視され、BUYやSELLのような単純なキーワードだけが認識されていました。
改善のポイント
この問題を解決するために、次の改善を行いました:
- 正規表現を使用した価格情報のパース: メッセージの内容に応じて、取引価格、TP、SLなどを正規表現で抽出するようにしました。これにより、メッセージの書式に依存せず、柔軟に情報を取得できるようになりました。
- 改行を保持して処理: メッセージの改行を削除せずに、そのまま処理することで、メッセージ内の構造を壊さずにパースできるようにしました。
- フォーマットされた情報をリストとして返す: シグナルメッセージの内容(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 “”
改善内容の詳細
- 正規表現の使用:
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.]+)'
これにより、複数行のメッセージや異なるフォーマットにも柔軟に対応できるようになりました。
- メッセージの構造を保持: メッセージが複数行に分かれていても、改行を保持することで、元の構造に基づいて情報を正確に取得できるようにしています。
- リスト形式での処理: シグナルの内容(BUY, SELL, TP, SLなど)をリスト形式で保持し、処理の流れを簡潔にしました。このリスト形式により、ファイルへの書き込みもスムーズに行えます。
まとめ
今回の改善により、Telegramボットがメッセージから取引に必要な詳細情報(価格、TP、SLなど)を正確にパースできるようになり、より堅牢なシグナル処理が可能となりました。改行を含むメッセージや複雑なフォーマットにも対応できるため、今後の拡張やメンテナンスも容易になります。
APIキーや保存パスは公開されていませんが、コードのロジックがどのように機能しているかを理解するための参考にしてください。
【Bitrue×そだし】無料で50USDTのオオバンブルマイ
Bitrueとそだしの限定コラボイベントが開催中です!
公式コラボレーションで安心・安全。この機会にご参加ください!
イベント内容と参加方法
🥇 ステップ1:新規登録+KYC2認証で50USDTプレゼント!
Bitrueで新規登録し、日本のKYC2認証を完了するだけで、50USDTがもらえます!
👉 今すぐ登録!
Bitrue公式サイト
🥈 ステップ2:500USDTの累計入金で追加50USDTを獲得!
累計で500USDT以上の入金を達成するだけで、さらに50USDTをゲットできます。
初めての入金でも大丈夫!お得にスタートできます。
🥉 ステップ3:取引で最大200USDTをゲット!
取引額に応じて、以下のボーナスを獲得👇
- 取引額50,000USDT以上 → 50USDTボーナス
- 取引額500,000USDT以上 → 200USDTボーナス
トレード好きな方には特におすすめです!
👉 イベントの詳細はこちら:イベントページを見る
リンクは本物です
今回のイベントは、Bitrueとそだしの公式コラボレーションです。
リンク先を確認していただければ、リアルなコラボであることがわかるはずです!
※リンクはBitrue公式サイトに直接繋がります。フィッシングサイトではないので、安心してご利用ください。
👉 Bitrue公式登録ページ
なぜそだしがBitrueとコラボできたのか?
そだしは2016年頃から活動している仮想通貨マイナーで、数々の経験を持っています。一時期は暗号資産メディアにも取り上げられ、そのつながりから、今回の世界有数の取引量を誇るBitrueとのコラボが実現しました。
今後も皆さまにイベント情報等を提供してまいります。引き続き当サイトのチェックをお願いします!
本当にUSDTがもらえるの?
本当にUSDTを受け取れます!もらったボーナスは送金や換金が可能です✨
私そだし自身が実際に試して確認済みなので、安心して参加してください。
※一般的なFXボーナスの「証拠金の水増し」とは異なり、リアルなボーナスとしてご利用いただけます!
投資は自己責任にて
まずは50USDTのデポジット、余裕があれば300USDTのボーナスを得て、新しい一歩を踏み出しましょう! 🎁
ただし、投資にはリスクが伴います。最終的な判断はご自身で慎重に行ってください。
楽しみながら、賢く投資を進めていきましょう!
👉 イベントの詳細はこちら