//+------------------------------------------------------------------+
//| Demo_FileWriteDouble.mq5 |
//| Copyright 2013, MetaQuotes Software Corp. |
//| https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2013, MetaQuotes Software Corp."
#property link "https://www.mql5.com"
#property version "1.00"
//--- montrons la fenêtre des paramètres d'entrée au lancement du script
#property script_show_inputs
//--- les paramètres pour la réception des données du terminal
input string InpSymbolName="EURJPY"; // la paire de devise
input ENUM_TIMEFRAMES InpSymbolPeriod=PERIOD_M15; // le temps trame
input int InpMAPeriod=10; // la période du lissage
input int InpMAShift=0; // le déplacement de l'indicateur
input ENUM_MA_METHOD InpMAMethod=MODE_SMA; // le type du lissage
input ENUM_APPLIED_PRICE InpAppliedPrice=PRICE_CLOSE; // le type du prix
input datetime InpDateStart=D'2013.01.01 00:00'; // la date de commencement du copiage des données
//--- les paramètres pour l'enregistrement des données au fichier
input string InpFileName="MA.csv"; // le nom du fichier
input string InpDirectoryName="Data"; // le nom du répertoire
//+------------------------------------------------------------------+
//| Script program start function |
//+------------------------------------------------------------------+
void OnStart()
{
datetime date_finish=TimeCurrent();
double ma_buff[];
datetime time_buff[];
int size;
//--- recevrons le handle de l'indicateur MA
ResetLastError();
int ma_handle=iMA(InpSymbolName,InpSymbolPeriod,InpMAPeriod,InpMAShift,InpMAMethod,InpAppliedPrice);
if(ma_handle==INVALID_HANDLE)
{
//--- on n'a pas réussi de recevoir le hadle de l'indicateur
PrintFormat("L'erreur de la réception du handle de l'indicateur. Le code de l'erreur = %d",GetLastError());
return;
}
//--- on se trouve dans le cycle, pendant que l'indicateur ne compte pas toutes ses valeurs
while(BarsCalculated(ma_handle)==-1)
Sleep(20); // le retard pour que l'indicateur puisse de calculer ses valeurs
PrintFormat("Les valeurs de l'indicateur seront enregistrées au fichier, à partir de %s",TimeToString(InpDateStart));
//--- copions les valeurs de l'indicateur
ResetLastError();
if(CopyBuffer(ma_handle,0,InpDateStart,date_finish,ma_buff)==-1)
{
PrintFormat("On n'a pas réussi de copier les valeurs de l'indicateur. Le code de l'erreur = %d",GetLastError());
return;
}
//--- copions le temps de l'apparition des barres correspondantes
ResetLastError();
if(CopyTime(InpSymbolName,InpSymbolPeriod,InpDateStart,date_finish,time_buff)==-1)
{
PrintFormat("On n'a pas réussi de copier les valeurs du temps. Le code de l'erreur = %d",GetLastError());
return;
}
//---recevrons la taille du tampon
size=ArraySize(ma_buff);
//--- désallouons la mémoire occupée par l'indicateur
IndicatorRelease(ma_handle);
//--- ouvrirons le fichier pour l'enregistrement des valeurs de l'indicateur (s'il n'existe pas, il sera créé automatiquement)
ResetLastError();
int file_handle=FileOpen(InpDirectoryName+"//"+InpFileName,FILE_READ|FILE_WRITE|FILE_BIN);
if(file_handle!=INVALID_HANDLE)
{
PrintFormat("Le fichier %s est ouvert pour l'enregistrement",InpFileName);
PrintFormat("La voie vers le fichier: %s\\Files\\",TerminalInfoString(TERMINAL_DATA_PATH));
//--- d'abord enregistrons la taille de l'extrait des données
FileWriteDouble(file_handle,(double)size);
//--- enregistrons le temps et les valeurs de l'indicateur dans le fichier
for(int i=0;i<size;i++)
{
FileWriteDouble(file_handle,(double)time_buff[i]);
FileWriteDouble(file_handle,ma_buff[i]);
}
//--- fermons le fichier
FileClose(file_handle);
PrintFormat("Les données sonr enregistrés, le fichier %s est fermé",InpFileName);
}
else
PrintFormat("On n'a pas réussi d'ouvrir le fichier %s, Le code de l'erreur = %d",InpFileName,GetLastError());
}
|