Maison >développement back-end >Tutoriel Python >Bot Telegram pour répliquer les signaux sur mt5

Bot Telegram pour répliquer les signaux sur mt5

Linda Hamilton
Linda Hamiltonoriginal
2024-12-15 07:56:08708parcourir

Telegram bot para replicar sinais no mt5

Nous analyserons et expliquerons le code en détail étape par étape. Ce script utilise la Bibliothèque Telethon pour se connecter à Telegram et reçoit les signaux d'un groupe, qui sont utilisés pour passer des commandes dans MetaTrader 5 (MT5). L'exécution du code implique de se connecter à MT5, d'écouter les messages sur Telegram et d'exécuter des ordres d'achat et de vente basés sur ces messages.

1. Importation de bibliothèque

from telethon import TelegramClient, events
import MetaTrader5 as mt5
import asyncio
import logging
from datetime import datetime
import signal
import os
import sys
import pkg_resources
  • Téléthon : Bibliothèque pour interagir avec Telegram (envoi et réception de messages).
  • MetaTrader5 : Bibliothèque qui permet d'interagir avec la plateforme MetaTrader 5, utilisée pour l'automatisation du trading.
  • asyncio : Pour travailler avec des opérations asynchrones, comme attendre des messages sur Telegram sans bloquer le programme.
  • logging : pour enregistrer les messages de journal qui aident au suivi et au débogage du code.
  • datetime : pour manipuler les dates et les heures.
  • signal : utilisé pour capturer les signaux du système, tels que le signal d'interruption (Ctrl C).
  • os, sys, pkg_resources : pour manipuler les fichiers, les répertoires et les ressources système.

2. Affichage des informations sur l'environnement

print("Python executando de:", sys.executable)
print("Ambiente virtual:", sys.prefix)
print("Versão do Python:", sys.version)
print("VIRTUAL_ENV:", os.environ.get('VIRTUAL_ENV'))

Ici, le code imprime des informations sur l'environnement dans lequel Python est exécuté, telles que la version de Python, le chemin de l'environnement virtuel et l'emplacement d'exécution de Python.

3. Liste des packages installés

installed_packages = [d for d in pkg_resources.working_set]
for package in installed_packages:
    print(package)

Le code affiche tous les packages Python installés dans l'environnement actuel, à l'aide de la bibliothèque pkg_resources.

4. Configuration de la journalisation

logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
logger = logging.getLogger(__name__)
  • Configure la journalisation pour enregistrer les messages au niveau INFO ou supérieur.
  • Format définit le format des messages de journal, qui inclut la date, le niveau de gravité et le message.

5. Paramètres du télégramme

API_ID = '78787878'
API_HASH = '12e957773a9a554cb6e32997122706f6'
PHONE_NUMBER = '+5512991111111'
GROUP_USERNAME = '@Nas100freepip'
  • API_ID et API_HASH : informations d'identification de l'API Telegram, requises pour utiliser Telethon.
  • PHONE_NUMBER : le numéro de téléphone du robot.
  • GROUP_USERNAME : Le nom du groupe Telegram à partir duquel le bot lira les messages.

6. Paramètres du compte MT5

CONTAS_MT5 = [
    {"login": 1690062, "senha": '5jsXlBg3~T', "servidor": 'ACGMarkets-Live', "us30": "US30.raw", "nas100": "NAS100.raw", "lote": 4.00}
]

Définit une liste de comptes MT5 que le bot peut utiliser pour exécuter des commandes. Chaque compte contient :

  • login : Le numéro de connexion au compte dans MetaTrader 5.
  • mot de passe : Le mot de passe du compte.
  • serveur : Le serveur du courtier.
  • us30 et nas100 : Les symboles des actifs à trader.
  • batch : La taille du lot pour les commandes.

7. Fonction pour se reconnecter à MT5

from telethon import TelegramClient, events
import MetaTrader5 as mt5
import asyncio
import logging
from datetime import datetime
import signal
import os
import sys
import pkg_resources

Cette fonction tente de se reconnecter à MetaTrader 5 pour un compte spécifique jusqu'au nombre maximum de tentatives (max_tries). Si la reconnexion échoue après le nombre de tentatives, elle renvoie False.

8. Fonction pour envoyer des commandes à MT5

print("Python executando de:", sys.executable)
print("Ambiente virtual:", sys.prefix)
print("Versão do Python:", sys.version)
print("VIRTUAL_ENV:", os.environ.get('VIRTUAL_ENV'))

Cette fonction envoie un ordre d'achat ou de vente à MetaTrader 5, selon le type d'action (achat ou vente). La fonction :

  • Vérifie la disponibilité des symboles.
  • Prépare la commande avec les informations nécessaires (prix, volume, type de commande, etc.).
  • Envoyer la commande à MT5.

9. Traitement du message reçu du télégramme

installed_packages = [d for d in pkg_resources.working_set]
for package in installed_packages:
    print(package)
  • Reçoit le message Telegram et le traite pour identifier l'actif (comme us30 ou nas100) et l'action (acheter ou vendre).
  • Pour chaque compte actif, essayez d'envoyer la commande en utilisant la fonction send_order. Si une commande échoue, le compte est supprimé de la liste des comptes actifs.

10. Fonction de vérification de connexion avec MT5

logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
logger = logging.getLogger(__name__)

Cette fonction vérifie périodiquement la connexion à MetaTrader 5 pour chaque compte actif. Si un compte ne parvient pas à se reconnecter, il est supprimé de la liste.

11. Traitement du signal d'interruption

API_ID = '78787878'
API_HASH = '12e957773a9a554cb6e32997122706f6'
PHONE_NUMBER = '+5512991111111'
GROUP_USERNAME = '@Nas100freepip'

Capture les signaux d'interruption (SIGINT ou SIGTERM), tels que la commande Ctrl C ou la fin du processus, et termine le programme proprement.

12. Fonction principale

CONTAS_MT5 = [
    {"login": 1690062, "senha": '5jsXlBg3~T', "servidor": 'ACGMarkets-Live', "us30": "US30.raw", "nas100": "NAS100.raw", "lote": 4.00}
]
  • Configure le gestionnaire de signal.
  • Initialise les connexions au compte MT5.
  • Crée le client Telegram, qui écoute les nouveaux messages dans le groupe spécifié. Lorsqu'un message arrive, il est traité et la commande correspondante est envoyée.
  • Attendra qu'un signal d'interruption soit reçu pour terminer le programme.

13. Exécution du code

async def reconectar_mt5(conta, max_tentativas=3):
    for tentativa in range(max_tentativas):
        try:
            if mt5.initialize(path=MT5_PATH, login=conta['login'], server=conta['servidor'], password=conta['senha']):
                logger.info(f"Reconexão bem-sucedida para conta {conta['login']}")
                return True
            else:
                logger.warning(f"Tentativa {tentativa + 1} de reconexão falhou para conta {conta['login']}: {mt5.last_error()}")
        except Exception as e:
            logger.error(f"Erro durante a tentativa {tentativa + 1} de reconexão para conta {conta['login']}: {e}")
        await asyncio.sleep(5)
    logger.error(f"Falha ao reconectar à conta {conta['login']} após {max_tentativas} tentativas")
    return False

La fonction main() est exécutée à l'aide de asyncio.run() pour gérer l'exécution de code asynchrone.


Conclusion:

Ce code est un bot de trading automatisé qui utilise Telegram pour recevoir des signaux d'achat et de vente, traite ces signaux et envoie des ordres à MetaTrader 5 pour négocier le marché selon les instructions reçues. Le code utilise une fonctionnalité asynchrone pour gérer plusieurs

Voici le code complet avec les détails expliqués précédemment :

from telethon import TelegramClient, events
import MetaTrader5 as mt5
import asyncio
import logging
from datetime import datetime
import signal
import os
import sys
import pkg_resources

Résumé des fonctions :

  1. reconnect_mt5 : Tentatives de reconnexion à MetaTrader 5 jusqu'à un nombre maximum de tentatives.
  2. send_order : envoie des ordres d'achat ou de vente à MetaTrader 5 en fonction des signaux reçus.
  3. process_signal : interprète les messages reçus de Telegram et exécute les ordres correspondants dans MetaTrader 5.
  4. verify_connections : Vérifie si la connexion à MetaTrader 5 est active et essaie de se reconnecter si nécessaire.
  5. signal_handler : gère les signaux d'interruption pour terminer le programme

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn