Keine Order setzen wenn letzter trade Buy/Sell
Hallo Forengemeinde,
Ich habe eine Frage zu einem Befehl, den ich in meinen Expert Advisor einbauen will. Ich möchte dass mein Expert Advisor keine neue Buy Order setzt, wenn die letzte Order bereits eine Buy Order war und genau dasselbe mit den Sell Positionen. Also sowas wie: if (LastOrder == OP_BUY && tu>0.000000001 && tu<9999999 && LastOrder != 1) {NO NEW ORDER SEND} habt ihr eine Idee, wie man das Programmieren könnte ? Gruss akuh |
Hi, so kann es gehen :
------------------------------------------------------------------ #include <stdlib.mqh> #include <WinUser32.mqh> // exported variables extern double BuyLots6 = 0.1; extern int BuyStoploss6 = 20; extern int BuyTakeprofit6 = 30; extern double SellLots7 = 0.1; extern int SellStoploss7 = 20; extern int SellTakeprofit7 = 30; // local variables double PipValue=1; // this variable is here to support 5-digit brokers bool Terminated = false; string LF = "\n"; // use this in custom or utility blocks where you need line feeds int NDigits = 4; // used mostly for NormalizeDouble in Flex type blocks int ObjCount = 0; // count of all objects created on the chart, allows creation of objects with unique names int current = 0; // current bar index, used by Cross Up, Cross Down and many other blocks int varylots[101]; // used by Buy Order Varying, Sell Order Varying and similar bool FirstTime2 = true; bool FirstTime4 = true; int init() { NDigits = Digits; if (false) ObjectsDeleteAll(); // clear the chart Comment(""); // clear the chart return (0); } // Expert start int start() { if (Bars < 10) { Comment("Not enough bars"); return (0); } if (Terminated == true) { Comment("EA Terminated."); return (0); } OnEveryTick1(); return (0); } void OnEveryTick1() { PipValue = 1; if (NDigits == 3 || NDigits == 5) PipValue = 10; CheckLastOrderType2(); CheckLastOrderType4(); } void CheckLastOrderType2() { int orderType = -1; int orderId = -1; datetime lastCloseTime = 0; int cnt = OrdersHistoryTotal(); for (int i=0; i < cnt; i++) { if (!OrderSelect(i, SELECT_BY_POS, MODE_HISTORY)) continue; if (OrderSymbol() == Symbol() && lastCloseTime < OrderCloseTime() && orderId == 1) { lastCloseTime = OrderCloseTime(); orderType = OrderType(); orderId = OrderMagicNumber(); } } if (orderType == OP_SELL || FirstTime2) { FirstTime2 = false; BuyOrder6(); } } void BuyOrder6() { double SL = Ask - BuyStoploss6*PipValue*Point; if (BuyStoploss6 == 0) SL = 0; double TP = Ask + BuyTakeprofit6*PipValue*Point; if (BuyTakeprofit6 == 0) TP = 0; int ticket = -1; if (true) ticket = OrderSend(Symbol(), OP_BUY, BuyLots6, Ask, 4, 0, 0, "My Expert", 1, 0, Blue); else ticket = OrderSend(Symbol(), OP_BUY, BuyLots6, Ask, 4, SL, TP, "My Expert", 1, 0, Blue); if (ticket > -1) { if (true) { bool sel = OrderSelect(ticket, SELECT_BY_TICKET); bool ret = OrderModify(OrderTicket(), OrderOpenPrice(), SL, TP, 0, Blue); if (ret == false) Print("OrderModify() error - ", ErrorDescription(GetLastError())); } } else { Print("OrderSend() error - ", ErrorDescription(GetLastError())); } } void CheckLastOrderType4() { int orderType = -1; int orderId = -1; datetime lastCloseTime = 0; int cnt = OrdersHistoryTotal(); for (int i=0; i < cnt; i++) { if (!OrderSelect(i, SELECT_BY_POS, MODE_HISTORY)) continue; if (OrderSymbol() == Symbol() && lastCloseTime < OrderCloseTime() && orderId == 1) { lastCloseTime = OrderCloseTime(); orderType = OrderType(); orderId = OrderMagicNumber(); } } if (orderType == OP_BUY || FirstTime4) { FirstTime4 = false; SellOrder7(); } } void SellOrder7() { double SL = Bid + SellStoploss7*PipValue*Point; if (SellStoploss7 == 0) SL = 0; double TP = Bid - SellTakeprofit7*PipValue*Point; if (SellTakeprofit7 == 0) TP = 0; int ticket = -1; if (true) ticket = OrderSend(Symbol(), OP_SELL, SellLots7, Bid, 4, 0, 0, "My Expert", 1, 0, Red); else ticket = OrderSend(Symbol(), OP_SELL, SellLots7, Bid, 4, SL, TP, "My Expert", 1, 0, Red); if (ticket > -1) { if (true) { bool sel = OrderSelect(ticket, SELECT_BY_TICKET); bool ret = OrderModify(OrderTicket(), OrderOpenPrice(), SL, TP, 0, Red); if (ret == false) Print("OrderModify() error - ", ErrorDescription(GetLastError())); } } else { Print("OrderSend() error - ", ErrorDescription(GetLastError())); } } int deinit() { if (false) ObjectsDeleteAll(); return (0); } ------------------------------------------------------------------ PS Code kommt aus meinem Generator. |
Das geht ganz einfach über wenige Zeilen:
Code:
int CheckOrder() { Wenn keine MagicNumber vergeben wird, dann einfach die letzte Abfrage in Zeile 4 löschen. traderdoc |
Zitat:
|
Zitat:
Gut, dann möchte ich Dir den gern aufzeigen: Mal abgesehen vom Schreibstil des Codes, der bei Dir extrem schwer zu lesen ist. Ich habe den mal aufgearbeitet, dann sieht man es auch besser. Code:
void CheckLastOrderType2() 1. In Zeile 8 wird die Historie vom Urschleim bis zur aktuell geschlossenen Order durchforstet. Das kostet ewig Zeit und ist unnötig, denn er wollte nur die letzte geschlossene Order haben und die liegt am Ende der OrdersHistory() und nicht am Anfang und daher for (int i = OrdersHistoryTotal()-1; i >= 0; i--) { 2. In Zeile 11 fehlt eigentlich die Abfrage nach der MagicNumber, sofern nicht auf eine expilizite Vergabe der MagicNumber verzichtet wird, also if (OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber) { 3. Und was soll das orderId == 1 eigentlich bewirken, außer dass der darunterstehende Klammerausdruck mit Zeile 13, 14 und 15 nie angesprungen wird, weil per se in der Funktionsdeklaration int orderID = -1 gesetzt wurde. 4. Damit bleibe auch lastCloseTime auf dem initialisierten Wert von 0 stehen, aber das würde dann eh keine Rolle mehr spielen, weil die Übergabe in Zeile 13 ja nicht angesprungen wird usw. usf. Was passiert nun wirklich in diesem Teil des EAs: 1. Der EA nimmt sich die Order mit der historischen Listennummer 0 2. Zeile 11 ergibt false, s.o. 3. Damit wird Zeile 13, 14 und 15 nicht angesprungen 4. Die for-Schleife rattert alls geschlossenen Orders durch - nix passiert 5. Nach Abschluß der for-Schleife wird geprüft, ob orderType == OP_SELL, also den Wert 1 hat, kann orderType aber nicht haben, weil immer noch der initialisierte Wert -1 in dieser Variablen steht (Zeile 14 wurde ja nicht angesprungen). 6. Da nun mit Installierung des EAs die Variable FirstTime2 auf true gesetzt wurde und in Zeile 18 eine ODER-Verknüpfung steht, ist die Abfrage in Zeile 18 true, wenigstens nur für den ersten Ansprung der Funktion CheckLastOrderType2(), denn in Zeile 20 wird diese Variable endgültig auf false gesetzt und nirgends im laufenden Programm wieder auf true. D.h. jedes weitere Anspringen dieser Funktion endet mit einem glatten Durchlauf der Funktion ohne Aktion! 7. Aber!!! Nur beim ersten! Durchlauf dieser Funktion wird die Funktion in Zeile 21 angesprungen und eine evtl. neue BuyOrder geöffnet. (Den Code habe ich mir nun nicht mehr angesehen) So, ich habe die Analyse mal etwas ausführlicher gestaltet, weil ich auch zeigen wollte, dass genau unter Verwendung irgendwelcher Generatoren ("PS Code kommt aus meinem Generator." - Zitat aus dem Post von @RetepM) nur Murks rauskommt, wenn man die Eingangsbedingungen nicht klar und eineindeutig beschreibt und am Ende den Code anscheinend auch nicht recht versteht und sich nur darauf verlässt. Wofür der Code auch immer generiert wurde, das Problem von @akuh löst er in keinster Weise. Viel Spass noch beim Erlernen von MQL4 auch im Jahre 2017. Prosit Neujahr! traderdoc PS. Sollte ich etwas übersehen haben, dann werde ich mich gern korrigieren. |
Hey
Erstmal Vielen Dank für die Antworten. Ich hab es mittlerweile folgendermassen gelöst: Code:
int LastOrderType() Ich stehe aber mittlerweile vor einem neuen Problem, das ich nicht gelöst kriege. Ich möchte gerne eine Sellstop bzw. Buystop position eröffnen, sobald der ask bzw bid Wert des aktuellen Kurses, höher bzw. niedriger ist als der Wert des Super-trend indicators. Ich habe bereits einige Versuche unternommen, aber keiner War erfolgreich. Hier sieht ihr meinen Code für die Eröffnung von buy/sell und buystop/sellstop positionen: Code:
double up = iCustom(NULL,PERIOD_M5,"HalfTrend_1",4,1); // returns EMPTY_VALUE when no arrow occurs gruss akuh |
Zitat:
Wenn eine Order nicht der OrderMagicNumber() und dem OrderSymbol() entspricht, wird jedesmal die Fehlermeldung geprintet. Da wird sich aber die Log-Datei freuen. Die wird dann richtig dick und fett und knabbert unaufhörlich an der Plattenkapazität. Weg damit! Und ob die letzte geschlossene Order eine Buy- oder Sell-Order ist, weiss ich auch nicht genau. Das könnte evtl. auch eine der evtl. gelöschten PendingOrders sein. Also man sollte schon sicherheitshalber nach den OrderType() == OP_BUY || OrderType() == OP_SELL fragen. traderdoc |
Hallo traderdoc
Ja du hast natürlich recht. Habe den Code schon geändert ! |
keine neue sell Order wenn vorherige auf Sell war und umgekehrt
Hallo Zusammen,
ich habe in meinem aktuellen EA, das gleiche Problem, dass nachdem das Indicatorsignal über iCustom vom Expert ausgeführt wird und in den TakeProfit oder auch Stoploss läuft unmittelbar eine neue Order platziert wird ohne auf das Gegensignal zu warten. Ich habe obige Lösung von Traderdoc probiert, jedoch erfolglos. platziert habe ich das Skript am ende des Ea´s . nach dem compilen gab es auch keine Fehlermeldung. folglich gehe ich davon aus, dass alles ok ist. ist es egal wo das Script eingepflegt wird? vielleicht erreicht die Routine gar nicht erst das script und wird deshalb nicht ausgeführt. vielen Dank für Eure Unterstützung |
hier zum evt.prüfen der EA:
extern string IS="---------------- Indicator Setting Heiken Ashi smoothed"; extern int MaMetod=2; extern int MaPeriod=6; extern int MaMetod2=3; extern int MaPeriod2=2; extern string LM="---------------- Money Management"; extern double Lots=0.01; extern bool MM=false; //money management extern double Risk=10; //risk in percentage extern string TSTB="---------------- TP SL TS BE"; bool RealSL_Enabled=false; int RealSL=5; //stop loss under 5 pîps bool RealTP_Enabled=false; int RealTP=10; //take profit under 10 pîps extern int SL=0; //stop loss extern int TP=0; //take profit extern int TS=0; //trailing stop extern int TS_Step=1; //trailing stop step extern int BE=0; //breakeven extern string EXT="---------------- Extras"; extern bool Reverse=false; extern bool Add_Positions=false; //positions cumulated extern int MaxOrders=1; //maximum number of orders extern int MagicNumber=09012017; int Slip=3;static int TL=0;double MML=0; // expert start function int start(){int j=0,limit=1;double BV=0,SV=0;BV=0;SV=0;double HA1,HA2; if(CntO(OP_BUY,MagicNumber)>0)TL=1;if(CntO(OP_SELL ,MagicNumber)>0)TL=-1;for(int i=1;i<=limit;i++){ HA1=iCustom(Symbol(),0,"Heiken_Ashi_Smoothed",MaMe tod,MaPeriod,MaMetod2,MaPeriod2,2,i); HA2=iCustom(Symbol(),0,"Heiken_Ashi_Smoothed",MaMe tod,MaPeriod,MaMetod2,MaPeriod2,3,i); if(HA2>HA1){if(Reverse)SV=1;else BV=1;break;} if(HA1>HA2){if(Reverse)BV=1;else SV=1;break;}} // expert money management if(MM){if(Risk<0.1||Risk>100){Comment("Invalid Risk Value.");return(0);} else{MML=MathFloor((AccountFreeMargin()*AccountLev erage()*Risk*Point*100)/(Ask*MarketInfo(Symbol(),MODE_LOTSIZE)*MarketInfo( Symbol(),MODE_MINLOT)))*MarketInfo(Symbol(),MODE_M INLOT);}} if(MM==false){MML=Lots;} // expert init positions int cnt=0,OP=0,OS=0,OB=0,CS=0,CB=0;OP=0;for(cnt=0;cnt< OrdersTotal();cnt++){OrderSelect(cnt,SELECT_BY_POS ,MODE_TRADES); if((OrderType()==OP_SELL||OrderType()==OP_BUY)&&Or derSymbol()==Symbol()&&((OrderMagicNumber()==Magic Number)||MagicNumber==0))OP=OP+1;} if(OP>=1){OS=0; OB=0;}OB=0;OS=0;CB=0;CS=0; // expert conditions to open position if(SV>0){OS=1;OB=0;}if(BV>0){OB=1;OS=0;} // expert conditions to close position if((SV>0)||(RealSL_Enabled&&(OrderOpenPrice()-Bid)/Point>=RealSL)||(RealTP_Enabled&&(Ask-OrderOpenPrice())/Point>=RealTP)){CB=1;} if((BV>0)||(RealSL_Enabled&&(Ask-OrderOpenPrice())/Point>=RealSL)||(RealTP_Enabled&&(OrderOpenPrice()-Bid)/Point>=RealTP)){CS=1;} for(cnt=0;cnt<OrdersTotal();cnt++){OrderSelect(cnt ,SELECT_BY_POS,MODE_TRADES); if(OrderType()==OP_BUY&&OrderSymbol()==Symbol()&&( (OrderMagicNumber()==MagicNumber)||MagicNumber==0) ){if(CB==1){OrderClose(OrderTicket(),OrderLots(),B id,Slip,Red);return(0);}} if(OrderType()==OP_SELL&&OrderSymbol()==Symbol()&& ((OrderMagicNumber()==MagicNumber)||MagicNumber==0 )){ if(CS==1){OrderClose(OrderTicket(),OrderLots(),Ask ,Slip,Red);return(0);}}}double SLI=0,TPI=0;int TK=0; // expert open position value if((AddP()&&Add_Positions&&OP<=MaxOrders)||(OP==0& &!Add_Positions)){ if(OS==1){if(TP==0)TPI=0;else TPI=Bid-TP*Point;if(SL==0)SLI=0;else SLI=Bid+SL*Point;TK=OrderSend(Symbol(),OP_SELL,MML ,Bid,Slip,SLI,TPI,OrSt,MagicNumber,0,Red);OS=0;ret urn(0);} if(OB==1){if(TP==0)TPI=0;else TPI=Ask+TP*Point;if(SL==0)SLI=0;else SLI=Ask-SL*Point;TK=OrderSend(Symbol(),OP_BUY,MML,Ask,Slip ,SLI,TPI,OrSt,MagicNumber,0,Lime);OB=0; return(0);}} for(j=0;j<OrdersTotal();j++){if(OrderSelect(j,SELE CT_BY_POS,MODE_TRADES)){if(OrderSymbol()==Symbol() &&((OrderMagicNumber()==MagicNumber)||MagicNumber= =0)){TrP();}}}return(0);} // expert number of orders int CntO(int Type,int Magic){int _CntO;_CntO=0; for(int j=0;j<OrdersTotal();j++){OrderSelect(j,SELECT_BY_P OS,MODE_TRADES);if(OrderSymbol()==Symbol()){if((Or derType()==Type&&(OrderMagicNumber()==Magic)||Magi c==0))_CntO++;}}return(_CntO);} //expert breakeven void TrP(){double pb,pa,pp;pp=MarketInfo(OrderSymbol(),MODE_POINT);i f(OrderType()==OP_BUY){pb=MarketInfo(OrderSymbol() ,MODE_BID); if(BE>0){if((pb-OrderOpenPrice())>BE*pp){if((OrderStopLoss()-OrderOpenPrice())<0){ModSL(OrderOpenPrice()+0*pp); }}} // expert trailing stop if(TS>0){if((pb-OrderOpenPrice())>TS*pp){if(OrderStopLoss()<pb-(TS+TS_Step-1)*pp){ModSL(pb-TS*pp);return;}}}} if(OrderType()==OP_SELL){pa=MarketInfo(OrderSymbol (),MODE_ASK);if(BE>0){if((OrderOpenPrice()-pa)>BE*pp){if((OrderOpenPrice()-OrderStopLoss())<0){ModSL(OrderOpenPrice()-0*pp);}}} if(TS>0){if(OrderOpenPrice()-pa>TS*pp){if(OrderStopLoss()>pa+(TS+TS_Step-1)*pp||OrderStopLoss()==0){ModSL(pa+TS*pp);return; }}}}} //expert stoploss void ModSL(double ldSL){bool fm;fm=OrderModify(OrderTicket(),OrderOpenPrice(),l dSL,OrderTakeProfit(),0,CLR_NONE);} //expert add positions function bool AddP(){int _num=0; int _ot=0; for (int j=0;j<OrdersTotal();j++){if(OrderSelect(j,SELECT_B Y_POS)==true && OrderSymbol()==Symbol()&&OrderType()<3&&((OrderMag icNumber()==MagicNumber)||MagicNumber==0)){ _num++;if(OrderOpenTime()>_ot) _ot=OrderOpenTime();}}if(_num==0) return(true);if(_num>0 && ((Time[0]-_ot))>0) return(true);else return(false);} // eine Order Script int CheckOrder () { for (int i = OrdersHistoryTotal () -1; i >=0; i--) { if ( !OrderSelect (i, SELECT_BY_POS, MODE_HISTORY)) continue; if (OrderSymbol () == Symbol () && OrderMagicNumber ()== MagicNumber) { if (OrderType () == 0 || OrderType () == 1) return(OrderType ()); } } return (-1); } |
@delipoint, sorry wenn ich als Erstes gleich mal die Axt schwinge.
Dieser Code geht gar nicht! Warum benutzt Du nicht in der Menüzeile das # Zeichen? Pro Codezeile nur eine Anweisung oder ein Vergleich und bitte alles schön einrücken nach einem {. Das muss übersichtlich bleiben, sonst liest doch keiner diesen Spaghetticode. Gehe mal davon aus, dass meine kleine Funktion CheckOrder() funktioniert. Das kann sie natürlich nur, indem sie an der entsprechenden Stelle aufgerufen wird. Ich sehe auf meinem iPad rechts nicht den ganzen Code, aber so weit ich das überblicke, wird doch die Funktion CheckOrder() überhaupt nicht aufgerufen. Also, schau mal, wo die Funktion hingehören soll und schreibe den Code mal durch vorheriges Drücken des # Zeichens. traderdoc |
Hi, meine Erfahrung ist, dass man besser fährt, wenn man bei erfolgter Order, eine Variable/Kondition (z.B. 1 für Buy-Order, 2 für Sell-Sellorder) setzt. Das hat den Vorteil, man kann diese Kondition relativ einfach auflösen, wenn andere Bedingungen schon erfüllt sind, CheckOrder (z.B. letzte Order war Buy) aber immer noch gelten würde.
|
Zitat:
Aber!! Die sauberere, aber v.a. sicherere Methode ist die, über die Abfrage der historischen Orders zu gehen. Warum? Nun ganz einfach: Wenn nicht Deine o.g. Variablenspeicherung als GlobalVariableSet() erfolgt, werden diese Variablen gelöscht, sobald der EA auch nur kurzfristig deaktiviert wird. Da reicht schon ein TimeFramewechsel aus oder eine andere "Unterbrechung". Somit wäre diese Variable auf den Initialwert zurückgesetzt. Mit der Abfrage über CheckOrder() spielen diese Szenarien keine Rolle und die letzte geschlossene Order mir mit Sicherheit sicher erkannt. Sollte es also möglich sein Variablen zu füllen über solche oder ähnliche Funktionen, dann ist das immer der temporären Speicherung von Variablen vorzuziehen. Eine "Notlösung" wäre wie geschrieben, das Schreiben der Variablen mittels GlobalVariableSet(). traderdoc |
Zitat:
Um Deine Einwänden aus dem Wege zu räumen, muss man tatsächlich etwas nachdenken. Eine einfache Lösung für den Wiedereinstieg wäre z.B. eine ganz normale externe Variable, über die man den Einstieg/Wiedereinstieg gesondert regeln kann. Aber eine globale Variable geht natürlich auch, die nimmt einem dann das Denken ab. Voraussetzung für erfolgreiches Trading mit einem EA ist natürlich, man muss wissen, wie funktioniert so ein Teil und was muss man grundsätzlich beachten bzw. was will man erreichen. |
Ja, warum sollte nicht das TF gewechselt werden, um sich ein Bild auch in anderen TFs zu verschaffen, mal ganz abgesehen vom unabsichtlichen TF-Wechsel.
Auch jede Änderung eine der Variablen in den Eigenschaften führt zum Verlust dieser temporären Variablenwerte. Ich denke auch an das Abschalten am Wochenende. Letztlich beschrieb ein User den Ausfall des Servers. All das und einige weitere Situationen führen zu einem Verlust dieser temporären Variablenwerte. Warum also unnötig dieses Risiko eingehen? Nun, wie willst Du denn das Problem über externe Variablen lösen? Gib uns bitte ein Code-Beispiel. Zitat @retepM: "Voraussetzung für erfolgreiches Trading mit einem EA ist natürlich, man muss wissen, wie funktioniert so ein Teil und was muss man grundsätzlich beachten bzw. was will man erreichen." Bei Deinem EA in Post #2 bin ich mir aber sicher, dass Du da nicht weisst, wie das Teil funktioniert, weil er eben nicht funktioniert. Die Erklärung dazu kam dann in Post #5. traderdoc |
Zitat:
Wenn Du Dir nicht sicher bist, dann antworte doch einfach nicht oder konzentriere Dich doch auf die Auftragsprogrammierung. In der Zeit, in der Du hier versuchst den Oberlehrer zu geben, könntest Du wahrscheinlich richtig was schaffen. Übrigens... ich habe nicht gegen sinnvolle Posts... Schönen Abend und viel Erfolg! In der Hoffnung auf weitere, wie ja meistens, positive Beiträge! |
Hehe!
Vertreib uns den Doc nicht. Der ist nicht der Oberlehrer, seine Code-Beispiele und seine Codeanalysen sind erste Sahne. Er macht das hier freiwillig und ohne Bezahlung und dafür sind wir ihm dankbar. Ich bewundere seine Geduld, einen Anfängercode zu analysieren. Kritik ist durchaus erlaubt, aber nicht beleidigend. Und echt: Warum soll man Timeframe nicht wechseln dürfen? Ist dein EA sauber geschrieben, dann macht das dem nichts aus. |
Zitat:
Erstens, wenn ich nicht eben durch die Auftragsprogrammierung am Kunden direkt erfahren hätte, was die so alles "anstellen" mit den EAs, dann hätte ich das doch gar nicht geschrieben. Vorausgesetzt der EA läuft im Live!!, würdest Du gern Geld verlieren, nur weil der EA in bestimmten Situationen dann nicht ordentlich läuft, aufgrund des Zurücksetzens der temporären Variablen? Ich glaube nicht. Und daher ist die Absicherung solcher Fälle das A und O. Der Mittelteil Deines Posts erschließt sich mir weder vom Inhalt noch von der Logik. Was hattest Du initiiert? Und v.a. wobei soll ich mir denn nicht sicher gewesen sein? Und warum sollte ich oberschlau sein, nur weil ich Deinen generierten EA zerlegt habe? Was falsch ist, sollte doch besser korrigiert werden, als dass es weiterhin dann so falsch hier stehenbleibt. Zum Entscheidenden hast Du leider noch nichts geschrieben. Ich würde schon gern so ein Codebeispiel sehen, wie Du dieses konkrete Problem über die Benutzung von externen Variablen regeln willst. traderdoc |
Hallo Zusammen, vielen Dank für das schnelle Antworten und dank an Traderdoc für die Programmierungshilfe.
Dennoch ist die Funktion noch immer nicht gegeben. Die Tatsache das das Script zur History-Abfrage der letzten Order an der falschen Stelle eingebettet war, dachte ich mir schon und habe nun folglich die Abfrage zwischen der Indicatorabfrage per (Icustom) und Initialisierung der Order gelegt. Leider nicht fehlerfrei global scobe Meldung die nicht wegzubekommen war. Die "# "Entscheidung als Brücke zur Abfrage ergab auch nur Fehlermeldungen. Ich brauche also weiterhin eure Unterstützung und sage schon mal herzlichen Dank Gruss delipoint |
Die Funktion incl. der Deklarierung
int CheckOrder() muss! außerhalb der start()-Funktion liegen, aber innerhalb der start()-Funktion aufgerufen werden mit CheckOrder(); traderdoc |
Mit dem # Zeichen meine ich natürlich den Button oben in der Menüzeile über dem Editierfenster. Nach dem Klicken darauf sollte dann im Text stehen:
Und zwischen ] und [ schreibst Du hier! den Code, jeweils schön eingerückt und übersichtlich. Das hat natürlich mit dem eigentlichen Code nichts zu tun, dient nur hier im Forum der übersichtlichen Dartellungsweise von Code. traderdoc |
Alle Zeitangaben in WEZ +2. Es ist jetzt 07:25 Uhr. |
Powered by vBulletin® Version 3.8.5 (Deutsch)
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
SEO by vBSEO 3.6.1
Powered by vBCMS® 2.7.0 ©2002 - 2024 vbdesigns.de
Copyright ©2009 - 2023 by Expert-Advisor.com - Das Metatrader Forum