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
Libérer: 2024-12-15 07:56:08
original
639 Les gens l'ont consulté

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
Copier après la connexion
Copier après la connexion
Copier après la connexion
  • 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'))
Copier après la connexion
Copier après la connexion

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)
Copier après la connexion
Copier après la connexion

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__)
Copier après la connexion
Copier après la connexion
  • 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'
Copier après la connexion
Copier après la connexion
  • 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}
]
Copier après la connexion
Copier après la connexion

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
Copier après la connexion
Copier après la connexion
Copier après la connexion

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'))
Copier après la connexion
Copier après la connexion

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)
Copier après la connexion
Copier après la connexion
  • 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__)
Copier après la connexion
Copier après la connexion

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'
Copier après la connexion
Copier après la connexion

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}
]
Copier après la connexion
Copier après la connexion
  • 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
Copier après la connexion

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
Copier après la connexion
Copier après la connexion
Copier après la connexion

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!

source:dev.to
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal