Sie verpassen Handelsmöglichkeiten:
- Freie Handelsapplikationen
- Über 8.000 Signale zum Kopieren
- Wirtschaftsnachrichten für die Lage an den Finanzmärkte
Registrierung
Einloggen
Sie stimmen der Website-Richtlinie und den Nutzungsbedingungen zu.
Wenn Sie kein Benutzerkonto haben, registrieren Sie sich
Ich verstehe nicht, was los ist. Es ist eine Linie von Minima.
Kopieren Sie den Code vorsichtshalber noch einmal, ich habe ihn dort regelmäßig geändert, vielleicht haben Sie eine alte Version
Ja, ich muss die Version beim Bearbeiten des Codes ändern.
AUDUSD scheint in Ordnung zu sein.
Ich werde über EURUSD für die Lotjahre gehen. Es wird lange dauern.
Ich würde gerne Woche und Monat auf einmal hinzufügen, wenn das nicht zu viel Mühe macht... Und ich würde gerne die Beschriftungen wie im Beispiel verschieben.
Damit ich mir das Diagramm nicht zehnmal ansehen muss. (Sie kennen die Geschichte bereits auswendig).
Ich glaube, ich schaffe 8 Paar in einem Monat.
Ich werde nicht selbst in Ihren Code einsteigen (ich werde den Prozess in aller Ruhe mit Klassen und so weiter anhand Ihres Beispiels studieren).
Beinahe hätte ich es vergessen (um eine Warnung auszugeben, wenn es keinen Verlauf gibt oder die Zeile ihre Werte nicht geändert hat)
Neue Version. Hier werden drei Zeiträume gezeichnet: Tag, Woche und Monat. Es gibt ein Aber, das ich weiter unten schreiben werde.
Der Unterschied besteht darin, dass wir im einen Fall den Vortag mit der Historie vergleichen und im anderen Fall die Vorwoche. Es stellt sich heraus, dass der gestrige Tag zwar zur aktuellen Woche gehört, sein Höchstwert aber höher sein kann als der Höchstwert der Vorwoche.
Und da wir Tage mit Tagen und Wochen mit Wochen vergleichen, kann sich herausstellen, dass die Linien der Tageshöchststände höher sind als die der Wochenhöchststände. Wie hier:
Aber das ist Ihre Logik, denken Sie nach, ob Sie es brauchen oder nicht.
Übrigens, es gibt auch einen Out-of-Array-Fehler:
Die Schleife durchläuft das Array der Tagesbalken, und wir wählen Elemente aus dem Array der Wochenbalken aus.
Dank an Dmitry Fedoseev für die Idee, die Nummer der Woche des Jahres zu erhalten.
Ich habe ihn in diesem Artikel gefunden:https://www.mql5.com/ru/articles/599
Gut gemacht, Dima!Übrigens, es gibt auch einen Out-of-Array-Fehler:
Die Schleife geht durch das Array der Tagesbalken, während wir Elemente aus dem Array der Wochenbalken auswählen.
Hier liegt ein offensichtlicher Fehler vor, diese Zeile wurde im Laufe der Diskussion hinzugefügt, und Copy-Paste spielte dabei eine Rolle.
Das war von Anfang an so, und das Überschreiten des Rahmens ist immer noch aktuell.
Wir können über den Fehler array out of range in vergessen, weil Sie nicht das Gefühl, faul und sofern viel mehr fortgeschrittenen Code (vielen Dank an Sie für das).
Aber ich möchte immer noch verstehen, was das Problem ist (da dieses Array von anderen Orten in der EA zugegriffen wird, und was dort vor sich geht bleibt ein Geheimnis)
Ich habe festgestellt (Wo wird der zurückgegebene Wert des Typs int gespeichert? Du hast alle Daten an die Funktion übergeben, aber nicht den ganzen Scheiß rausgeholt) habe ich hinzugefügt.
Es war folgendermaßen:
ArrayCopyRates(Bar_data_D1,_Symbol,PERIOD_D1); // Kopiert die Balkendaten des angegebenen Charts in ein Array und gibt die Anzahl der kopierten Balken zurück
ArrayCopyRates(Bar_data_W1,_Symbol,PERIOD_W1); // Kopiert die Daten der Balken für ein bestimmtes Diagramm in ein Array und gibt die Anzahl der kopierten Balken zurück
ArrayCopyRates(Bar_data_MN1,_Symbol,PERIOD_MN1); // Kopiert die Daten der Balken eines angegebenen Charts in ein Array und gibt die Anzahl der kopierten Balken zurück
Jetzt sieht es so aus:
ACR_D1 = ArrayCopyRates(Bar_data_D1,_Symbol,PERIOD_D1); // Kopiert die Balkendaten des angegebenen Charts in ein Array und gibt die Anzahl der kopierten Balken zurück
ACR_W1 = ArrayCopyRates(Bar_data_W1,_Symbol,PERIOD_W1); // Kopiert die Daten der Balken für ein bestimmtes Diagramm in ein Array und gibt die Anzahl der kopierten Balken zurück
ACR_MN1 = ArrayCopyRates(Bar_data_MN1,_Symbol,PERIOD_MN1); // Kopiert Daten von Balken in einem angegebenen Diagramm in ein Array und gibt die Anzahl der kopierten Balken zurück
Ausgabe des Wertes im som
2020.12.12 16:51:31.536 2020.02.10 00:05:00 _Test AUDUSD,H1: i = 1001 Bar_data_D1 [i][2] = 0.7633799999999999
2020.12.12 16:51:31.536 2020.02.10 00:05:00 _Test AUDUSD,H1: i = 1002 Bar_data_D1 [i][2] = 0.76147
2020.12.12 16:51:31.536 2020.02.10 00:05:00 _Test AUDUSD,H1: i = 1003 Bar_data_D1 [i][2] = 0.75097
2020.12.12 16:51:31.536 2020.02.10 00:05:00 _Test AUDUSD,H1: array out of range in '_Test.mq4' (150,59)
2020.12.12 16:51:31.537 2020.02.10 00:05:00 Testdurchlauf gestoppt aufgrund eines kritischen Fehlers im EA
2020.12.12 16:51:31.537 AUDUSD,H1: 65147 Tick-Ereignisse (73 Balken, 9291875 Balkenzustände) verarbeitet in 0:00:02.407 (Gesamtzeit 0:00:05.672)
Warum wird so wenig Geschichte in das Feld kopiert?
Und wo und wie kommen diese Werte überhaupt her?
Übrigens, es gibt auch einen Out-of-Array-Fehler:
Die Schleife durchläuft das Array der Tagesbalken, und wir wählen Elemente aus dem Array der Wochenbalken aus.
Wir sollten sofort verstehen, wie groß das Feld der täglichen TF ist und es zeitlich einordnen und nicht über die Zeit hinausgehen.
Die wöchentlichen Balken würde ich wahrscheinlich anders lösen. Ich würde die Preisniveaus mit den wöchentlichen Daten abrufen, wenn sie benötigt werden, und sie in ein separates Array füllen und mit diesem Array vergleichen. Oder besser gesagt, so mache ich es. Für jede TF meine eigene Reihe von Extrema.
Ich mache keine Vergleiche, ich spreche über Arrays
Und sofort verstehen, wie groß das tägliche TF-Feld ist, und es zeitlich einordnen und pünktlich bleiben.
Die wöchentlichen Aufgaben würde ich wahrscheinlich anders lösen. Ich würde die Preisniveaus mit den wöchentlichen Terminen abfragen, wenn sie benötigt werden, und sie in ein separates Array eintragen und mit diesem Array vergleichen. Oder besser gesagt, so mache ich es. Für jede TF habe ich meine eigene Reihe von Extrema.
Ich ziehe keine Vergleiche, ich spreche von Arrays.
(Ich würde Preisniveaus mit Datumsangaben abrufen, wenn sie benötigt werden, und sie in ein separates Array füllen und mit diesem Array vergleichen)
Wir wissen nicht, welche wir brauchen und welche nicht, wir brauchen alle möglichen Geschichten von allen Bars.
ArrayCopyRates
Kopiert die Daten der angegebenen Diagrammbalken in ein Array und gibt die Anzahl der kopierten Balken zurück.
intArrayCopyRates(
MqlRates&rates_array[],// Array MqlRates übergeben durch die Referenz
stringsymbol=NULL,// das Werkzeug
intZeitrahmen=0// Zeitrahmen
);
Wo ist es nicht klar?
Ich kann den Zusammenhang nicht erkennen
Er sieht 323 Monate, was in etwa 27 Jahren, 1403 Wochen und 7015 Tagen entspricht.
AUDUSD-Verlauf seit 1993, 2020-1993= 27
(Ermitteln Sie bei Bedarf Preisniveaus mit Datumsangaben, legen Sie sie in ein separates Array und vergleichen Sie sie mit diesem Array).
Wir wissen nicht, welche wir brauchen und welche nicht, wir brauchen alle möglichen Geschichten von allen Bars.
ArrayCopyRates
Kopiert die Daten der angegebenen Diagrammbalken in ein Array und gibt die Anzahl der kopierten Balken zurück.
intArrayCopyRates(
MqlRates&rates_array[],// Array MqlRates übergeben durch die Referenz
stringsymbol=NULL,// das Werkzeug
intZeitrahmen=0// Zeitrahmen
);
Wo ist es nicht klar?
Ich kann den Zusammenhang nicht erkennen
Er sieht 323 Monate, was in etwa 27 Jahren, 1403 Wochen und 7015 Tagen entspricht.
AUDUSD-Verlauf seit 1993, 2020-1993= 27
Keine Vorstellung davon, was gemessen oder bestimmt werden kann. Zuerst messen wir die Reichweite, und wir wissen.
Wenn wir alle Extrema in den täglichen Daten über 27 Jahre aufschreiben und die gleichen identifizieren, werden es zu viele sein. Die Aufgabe ist ähnlich wie die Identifizierung von Kopien auf einer Disc, nur einfacher.