Qualsiasi domanda da principiante, per non ingombrare il forum. Professionisti, non passate oltre. Da nessuna parte senza di te - 6. - pagina 1129
Ti stai perdendo delle opportunità di trading:
- App di trading gratuite
- Oltre 8.000 segnali per il copy trading
- Notizie economiche per esplorare i mercati finanziari
Registrazione
Accedi
Accetti la politica del sito e le condizioni d’uso
Se non hai un account, registrati
C'è una possibilità, se l'EA (o lo script) è a vostra disposizione dal punto di vista di prendere e correggere il codice sorgente. Devi mettere una condizione intorno a tutti gli avvisi che controlla se il pulsante è premuto. Se il pulsante non viene premuto, non chiamare gli allarmi.
GrazieVladimir - penso che userò il tuo metodo o metterò l'intero EA in questa condizione.
Grazie a Vitalie Postolache- studierò la sua raccomandazione. Non ho ancora studiato mql5.
Ho bisogno di scrivere i dati in un file hst, in modo da poter utilizzare i dati per costruire un grafico autonomo.
Sto lottando da due giorni ma non funziona niente.
Codice:
#property link "https://www.mql5.com"
#property version "1.00"
#property strict
ulong last_fpos=0; //
int HandleHistory=-1;
//+------------------------------------------------------------------+
//| Script program start function |
//+------------------------------------------------------------------+
void OnStart()
{
string symbol=Symbol();
int per=Period()*9;
ResetLastError();
if(CreateHeader()==true)//если создали заголовок
{
HandleHistory=FileOpenHistory(symbol+(string)per+".hst",FILE_BIN|FILE_WRITE|FILE_SHARE_WRITE|FILE_SHARE_READ|FILE_ANSI);
if(HandleHistory!=INVALID_HANDLE)
{
for(int i=199;i>0;i--)//заполняем данными
{
MqlRates r;
r.time=Time[i];//просто пытаюсь записать, это так для примера
r.open=Open[i];//просто пытаюсь записать, это так для примера
r.low=Low[i];
r.high=High[i];
r.close=Close[i];
r.tick_volume=(long)10;
r.spread=0;
r.real_volume=(long)10;
uint byteswritten=FileWriteStruct(HandleHistory,r);
Print("FileOpen OK ",byteswritten," ",Time[i]);
}
FileClose(HandleHistory);
// FileFlush(HandleHistory);
}
else Print("Операция FileOpen неудачна, ошибка ",GetLastError());
}
// long id=ChartOpen(symbol,per);
//Alert(id);
}
//+------------------------------------------------------------------+
bool CreateHeader()//создаем файл с историей hst(заголовок)
{
int file_version=401;
string c_copyright;
string c_symbol=Symbol();
int i_period=Period()*9;
int i_digits=Digits;
int i_unused[13];
//---
ResetLastError();
HandleHistory=FileOpenHistory(c_symbol+(string)i_period+".hst",FILE_BIN|FILE_WRITE|FILE_SHARE_WRITE|FILE_SHARE_READ|FILE_ANSI);
if(HandleHistory<0)
{
Print("Error open ",c_symbol+(string)i_period,".hst file ",GetLastError());
return(false);
}
c_copyright="(C)opyright 2003, MetaQuotes Software Corp.";
ArrayInitialize(i_unused,0);
//--- write history file header
FileWriteInteger(HandleHistory,file_version,LONG_VALUE);
FileWriteString(HandleHistory,c_copyright,64);
FileWriteString(HandleHistory,c_symbol,12);
FileWriteInteger(HandleHistory,i_period,LONG_VALUE);
FileWriteInteger(HandleHistory,i_digits,LONG_VALUE);
FileWriteInteger(HandleHistory,0,LONG_VALUE);
FileWriteInteger(HandleHistory,0,LONG_VALUE);
FileWriteArray(HandleHistory,i_unused,0,13);
return(true);
}
Come risultato dell'esecuzione viene creato un file con la storia, ma non viene creato un grafico autonomo.
Ecco le informazioni sul grafico
Per qualche ragione, i dati sono del 2003!
Come risultato, ottengo un errore quando lancio il grafico HistoryBase: 196 errori in 'NZDCHF45'.
Capisco che ho scritto qualcosa di sbagliato. Non so come scriverlo correttamente, ho troppe poche informazioni. Chi lo sa - per favore consigliatemi.
forse questo è un estratto da un progetto molto, molto vecchio (C, gcc):
/* .hst file header
*/
struct HstHeader {
uint32_t version; // +0 4 LE : database version
char copyright[64]; // +4 64 : copyright data
char symbol[12]; // +68 12 : symbol (EURUSD..)
uint32_t period; // +80 4 LE : timeframe (sec. in period)
uint32_t digits; // +84 4 LE : decimals after .
datetime timesign; // +88 4 LE : creation time sign.
datetime last_sync; // +92 4 LE : last sync. timestamp
uint8_t unused[52]; // +96 52 : reserved for feauture use
// total 148 bytes, packed, aligned by 1
};
/* .hst bar array (file payload)
*/
// when HstHeader.version==400
struct HstRates400 {
datetime ctm; // +0 4 LE : start (creation) time
double open; // +4 8 LE : open price
double low; // +12 8 LE : lowest price
double high; // +20 8 LE : highst price
double close; // +28 8 LE : close price
double volume; // +36 8 LE : volume (nr of ticks)
// total 44 bytes,packed, aligned by 1
} __attribute__((packed));
// when HstHeader.version==401
struct HstRates401 {
datetime ctm; // +0 8 LE : bar start time (with ms?)
double open; // +8 8 LE : open price
double low; // +16 8 LE : lowest price
double high; // +24 8 LE : highst price
double close; // +32 8 LE : close price
uint64_t volume; // +40 8 LE : volume (nr of ticks)
uint32_t spread; // +48 4 LE : spread
long real_volume; // +52 8 LE : real volume
// total 60 bytes,packed,aligned by 1
} __attribute__((packed));
Ciao a tutti, continuando a perfezionare ciò che abbiamo già
Abbiamo una griglia irregolare di ordini e una linea orizzontale che può essere ovunque
Dobbiamo implementare questo:
se il prezzo è sotto la linea chiudere tutti gli ordini
Le difficoltà sono le seguenti
1) se gli ordini sono di tipo non uniforme e già quando si imposta la linea si fa tutto, e non quando si mette la marcatura e si imposta la linea (in questo caso si dovrebbe impostare anche il flag on/off)
2) Implementazione di un'iscrizione in alto a destra della linea per tipo (se l'ordine viene chiuso a questo prezzo, il risultato sarà lo stesso per il saldo, cioè, dobbiamo cambiare la visualizzazione ogni tick e anche quando si sposta la linea; è generalmente simile a un trailing stop o sl se l'ordine viene piazzato manualmente, solo fluttuante e con la possibilità di trigger errati inizialmente)
Il robot è lì, tranne il marcatore numerico tutto è già disegnato, la questione è nella corretta assegnazione dei valori e nell'elaborazione delle informazioni di tutta la griglia.
1) se gli ordini sono di tipo irregolare
Salve. Non capisco perché iTime a volte dà l'ora sbagliata. All'apertura di una nuova candela PERIOD_H1 dovrebbe mostrare il tempo nel log Print(iTime(NULL,PERIOD_M1,30)). Visualizza tutto correttamente nei test, ma nella realtà l'ora è a volte diversa anche di diverse ore. Perché è così?
UsateCopyTime, anche io ho notato questo problema quando costruivo oggetti grafici eCopyTime ha risolto il problema
if(CopyTime(Symbol(),Period(),0,1,TM)<0) return;
TIME0=TM[0];
UsateCopyTime, anche io ho notato questo problema quando costruivo oggetti grafici eCopyTime ha risolto il problema
if(CopyTime(Symbol(),Period(),0,1,TM)<0) return;
TIME0=TM[0];
È la prima volta che ne sento parlare.
Qui, il grafico ha 5 cifre e l'indicatore ne ha 4.
Come faccio a far sì che la scala del mio indicatore mostri 5 cifre decimali?
Qui, il grafico ha 5 cifre e l'indicatore ne ha 4.