新人对MQL4和MQL5的任何问题,对算法和代码的帮助和讨论 - 页 55 1...484950515253545556575859606162...1953 新评论 Vitalie Postolache 2017.01.04 17:33 #541 trader781: 我还没有使用类、数组、宏和从Windows库导入。所有的时间都很充裕。 你不应该用数组来做。数组是很方便的。结构也是如此。其余的,是的,如果项目 不是很复杂,你可能根本就不会使用。 Vitaly Muzichenko 2017.01.04 18:04 #542 Vitalie Postolache: 对于数组来说,这就是一种浪费。数组是很方便的。结构也是如此。其余的,是的,如果项目不复杂,就根本不可能使用。 至于数组,我同意它们非常方便,没有它们,你往往无法写出一个合理的程序。结构...我喜欢在网络程序中使用类,这确实不方便,特别是如果项目 很大的话,而且我不喜欢在通常的单页专家顾问中使用MQ。我在OOP中写了所有开放/封闭的数据,开始使用并删除了所有的东西,以程序化的风格和使用方式重写,在一个循环中写了所有东西。因此,课程有点后天的味道。 Vitalie Postolache 2017.01.04 18:10 #543 Vitaly Muzichenko: 我同意数组非常方便,没有数组你往往无法合理地编写一个程序。结构...我在网络程序中写课,没有它们真的不好,也不方便,特别是如果项目很大的话,但我不喜欢通常单页的专家顾问中的MQ。我已经用OOP写了所有关于open/closed的数据,开始使用并删除了所有的东西,用程序化风格重写并使用,在一个循环中写了所有东西。所以课程是为爱好者准备的。 嗯。这与上课有什么关系?结构和类是有点不同的东西。我写了关于结构的文章。MqlRates 等等,等等...... Vadim Podoprigora 2017.01.04 21:15 #544 请帮我添加最大未结订单数(MAXORders) // extern string rem2 = "=== 手数 ===;外部双 _Lots0_1 = 0.1; // 基础级别(对于第一个订单)外部双 _Lots0_2 = 0.1; // 基础级别(对于第二个订单) // extern string rem3 = "=== 附加参数 ==="; extern int _TakeProfit1_Proc = 50; // 第一个订单的获利风险百分比外部 int _SpaseFromMaxMin = 1; // 从顶部/底部偏移// extern string rem4 = "=== 盈亏平衡参数 ==="; extern bool _IsStopLoss_0 = false; // 启用盈亏平衡水平extern int _StopLoss_0_From = 0; // 从盈亏平衡水平偏移(以点为单位) extern int _StopLoss_0_Level = 15; //盈亏平衡水平// extern string rem5 = "=== 追踪止损参数 ==="; extern bool _IsTrailingStop = false; // 启用追踪止损bool _IsTrailingStopProfit = true; // 从盈亏平衡位置启用追踪止损//extern int _TrailingStopProfit_From = 0; // 从盈亏平衡水平偏移(以点为单位)外部 int _TrailingStopLevel = 15; // 追踪止损水平外部 int _TrailingStopStep = 5; // 追踪止损移动步骤// extern string rem6 = "=== 工具设置 ===";外部字符串 _Symboll = ""; // 工具的符号名称:"" - 当前符号extern int _Timeframe = 0; // Period: 0 - 当前图表的周期int_Digitss; // 价格小数点后的位数双 _Points; // 报价货币的点数extern int _Slippage = 2; // 滑点外部 int _Magic1 = 1281; // 唯一数量的 EA 订单(第一个订单)外部 int _Magic2 = 1282; // 唯一数量的 EA 订单(第二个订单) // extern string rem7 = "=== MA1 指标参数 ===; extern int _MA1_Timeframe = PERIOD_D1; // Period: 0 - 当前图表的周期extern int _MA1_Period = 20; // 计算移动平均线的平均周期外部 int _MA1_Shift = 0; // 指标相对于价格图表的偏移外部 int _MA1_Method = 0; // 平均方法:0 - SMA, 1 - EMA, 2 - SMMA, 3 - LWMA extern int _MA1_Applied_Price = 0; // 使用价格:0 - 收盘价,1 - 开盘价,2 - 最高价,3 - 最低价// extern string rem8 = "=== MA2 指标参数 ==="; extern int _MA2_Timeframe = PERIOD_H4; // Period: 0 - 当前图表的周期extern int _MA2_Period = 20; // 计算移动平均线的平均周期外部 int _MA2_Shift = 0; // 指标相对于价格图表的偏移外部 int _MA2_Method = 0; // 平均方法:0 - SMA, 1 - EMA, 2 - SMMA, 3 - LWMA extern int _MA2_Applied_Price = 0; // 使用价格:0 - 收盘价,1 - 开盘价,2 - 最高价,3 - 最低价// extern string rem9 = "=== 布林带指标参数 ==="; //extern int _BB_Timeframe = 0; // Period: 0 - 当前图表的周期extern int _BB_Period = 20; // 主指标线的平均周期外部 int _BB_Deviation = 2; // 偏离主线外部 int _BB_Bands_Shift = 0; // 指标相对于价格图表的偏移extern int _BB_Applied_Price = 0; // 使用价格:0 - 收盘// extern string rem10 = "=== ZigZag 指标参数 ==="; //extern int _ZZ_Timeframe = 0; // Period: 0 - 当前图表的周期外部 int _ZZ_ExtDepth = 12;外部 int _ZZ_ExtDeviation = 5; extern int _ZZ_ExtBackstep = 3; // datetime_TimePrevious;日期时间_TimeCurrent; // string_fstr; int_tp; //无效 MaxOrders(int max_orders=5); //=++============================================== ================++=初始化初始化() { if(_Symbol == "") _Symbol = Symbol(); // _Digitss = MarketInfo(_Symbol, MODE_DIGITS); _Points = MarketInfo(_Symbol, MODE_POINT); // if(_Timeframe == 0) _Timeframe = Period(); Print("v128-2 > init() >> _Timeframe=", _Timeframe, "rem4=",_IsStopLoss_0, "rem5=",_IsTrailingStop,_IsTrailingStopProfit); // _fstr = "v128_"; _tp = _FileReadWriteDouble(_fstr+"_tp.dat", 0); // 确保文件存在,如果不存在,则创建它Print("v128-2 > init() >> _Timeframe=", _Timeframe, " _tp=",_tp); // _TimePrevious=iTime(_Symbol, _Timeframe, 0); // Print("v128-2 > 完成:init() >> _TimePrevious=", _TimePrevious, " (", TimeToStr(_TimePrevious,TIME_DATE|TIME_MINUTES), ")");返回(0); } //=++============================================== ================++=整数开始() {双 P_Close1,P_Close2;双 BB_1_upper,BB_1_lower;双 MA1_0,MA2_0;双 P_ask,P_bid; bool is_signal_2_buy, is_signal_2_sell;双 P1_buy、P2_buy、P3_buy;双 P1_sell、P2_sell、P3_sell;布尔 is_b1 = 假,is_s1 = 假;布尔 is_b2 = 假,is_s2 = 假;国际票; // _TimeCurrent = iTime(_Symbol, _Timeframe, 0);如果(_TimeCurrent != _TimePrevious) { MA1_0 = iMA(_Symbol, _MA1_Timeframe, _MA1_Period, _MA1_Shift, _MA1_Method, _MA1_Applied_Price, 0); MA2_0 = iMA(_Symbol, _MA2_Timeframe, _MA2_Period, _MA2_Shift, _MA2_Method, _MA2_Applied_Price, 0); BB_1_upper = iBands(_Symbol, _Timeframe, _BB_Period,_BB_Deviation,_BB_Bands_Shift,_BB_Applied_Price, MODE_UPPER, 1); BB_1_lower = iBands(_Symbol, _Timeframe, _BB_Period,_BB_Deviation,_BB_Bands_Shift,_BB_Applied_Price, MODE_LOWER, 1); P_Close1 = iClose(_Symbol, _Timeframe, 1); P_Close2 = iClose(_Symbol, _Timeframe, 2); P_ask = MarketInfo(_Symbol, MODE_ASK); P_bid = MarketInfo(_Symbol, MODE_BID); Print("v120-4 > ", _Symbol, " | ", _Timeframe, " -> MA1_0=", MA1_0, " | MA2_0=", MA2_0, " -> BB_1_upper=", BB_1_upper, " | BB_1_lower=", BB_1_lower, " -> P_Close1=", P_Close1, " | P_Close2=", P_Close2, " -> ask=", P_ask, " | bid=", P_bid); // is_signal_2_buy = P_bid >= MA1_0 && P_bid >= MA2_0 && P_Close1 >= BB_1_lower && P_Close2 <= BB_1_lower && P_bid >= BB_1_lower; is_signal_2_sell = P_bid <= MA1_0 && P_bid <= MA2_0 && P_Close1 <= BB_1_upper && P_Close2 >= BB_1_upper && P_bid <= BB_1_upper; Print("v128-2 > ", _Symbol, " | ", _Timeframe, " -> is_signal2 -> 购买=", is_signal_2_buy, " | 出售=", is_signal_2_sell); // ========== 按市场// ========== 开启买单如果(is_signal_2_buy) { Print("v128-2 > ", _Symbol, " | ", _Timeframe, " -> 发出开买单的信号"); OrdersDeleteAll(OP_SELL); //如果(!is_b1 || !is_b2) { P1_buy = P_ask; P3_buy = FindPriceMinMax(false) - (_SpaseFromMaxMin) * _Point; _tp = (P1_buy - P3_buy) / _Point * (_TakeProfit1_Proc / 100.0); P2_buy = DoubleTestZero(_tp, P1_buy + (_tp) * _Point); // _FileWriteDouble(_fstr+"_tp.dat", _tp); // Print("v128-2 > ", _Symbol, " | ", _Timeframe, “ -> 购买 -> P1_buy=", P1_buy, " | P2_buy=", P2_buy, " | P3_buy=", P3_buy, "_tp=", _tp); //票 = OrderSend(_Symbol, OP_BUY, _Lots0_1, ND(P1_buy), _Slippage, ND(P3_buy), ND(P2_buy), NULL, _Magic1, 0, CLR_NONE);如果(票 == -1) Print("v128-2 > ", _Symbol, " | ", _Timeframe, " -> BUY (1) > 错误(开盘)#", GetLastError());否则 is_b1 = true; //票 = OrderSend(_Symbol, OP_BUY, _Lots0_2, ND(P1_buy), _Slippage, ND(P3_buy), 0, NULL, _Magic2, 0, CLR_NONE);如果(票 == -1) Print("v128-2 > ", _Symbol, " | ", _Timeframe, " -> 购买 (2) > 错误(开盘)#", GetLastError());否则 is_b2 = true; // }否则 { is_b1 = true; is_b2 = 真; } }否则 { is_b1 = true; is_b2 = 真; } //打印("=买+++",is_b1,is_b2,"==",is_s1,is_s2); // ========== 开卖单如果(is_signal_2_sell) { Print("v128-2 > ", _Symbol, " | ", _Timeframe, " -> 发出开卖单的信号"); OrdersDeleteAll(OP_BUY); //如果(!is_s1 || !is_s2) { P1_sell = P_bid; P3_sell = FindPriceMinMax(true) + (_SpaseFromMaxMin) * _Point; _tp = (P3_sell - P1_sell) / _Point * (_TakeProfit1_Proc / 100.0); P2_sell = DoubleTestZero(_tp, P1_sell - (_tp) * _Point); // _FileWriteDouble(_fstr+"_tp.dat", _tp); // Print("v128-2 > ", _Symbol, " | ", _Timeframe, “ -> 买入 -> P1_sell=", P1_sell, " | P2_sell=", P2_sell, " | P3_sell=", P3_sell); //票 = OrderSend(_Symbol, OP_SELL, _Lots0_1, ND(P1_sell), _Slippage, ND(P3_sell), ND(P2_sell), NULL, _Magic1, 0, CLR_NONE);如果(票 == -1) Print("v128-2 > ", _Symbol, " | ", _Timeframe, " -> SELL (1) > Error (opening) #", GetLastError());否则 is_s1 = true; //票 = OrderSend(_Symbol, OP_SELL, _Lots0_2, ND(P1_sell), _Slippage, ND(P3_sell), 0, NULL, _Magic2, 0, CLR_NONE);如果(票 == -1) Print("v128-2 > ", _Symbol, " | ", _Timeframe, " -> SELL (2) > Error (opening) #", GetLastError());否则 is_s2 = true; // }否则 { is_s1 = true; is_s2 = 真; } }否则 { is_s1 = true; is_s2 = 真; } //打印("=卖+++",is_b1,is_b2,"==",is_s1,is_s2); // ========== if(is_b1 && is_s1 && is_b2 && is_s2) _TimePrevious=_TimeCurrent; } //如果(_IsTrailingStop) { if( !FindOrders(_Magic1) ) TrailingStop(_tp); } //如果(_IsStopLoss_0) StopLoss_0(_StopLoss_0_From); //返回(0); } //=++============================================== ================++=双 DoubleTestZero(双值,双新值) {如果(值==0)返回(值);否则返回(新值); } //=++============================================== ================++=双ND(双值) {返回(NormalizeDouble(值,_Digits)); } //=++============================================== ================++= // 关闭订单。全部关闭时结束无效 OrdersDeleteAll(int cmd) {而(CountOrders(cmd)> 0) { for(int i = OrdersTotal() - 1; i >= 0 ; i--) { if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if((OrderSymbol() == _Symbol) && (OrderMagicNumber() == _Magic1 || OrderMagicNumber() == _Magic2) && (OrderType() == cmd) ) { if(OrderType() == OP_BUY) if(!OrderClose(OrderTicket(), OrderLots(), MarketInfo(OrderSymbol(), MODE_BID), _Slippage, CLR_NONE)) Print("v128-2 > ", _Symbol, " > BUY -> ticket=", OrderTicket(), " -> 错误(关闭)#", GetLastError()); if(OrderType() == OP_SELL) if(!OrderClose(OrderTicket(), OrderLots(), MarketInfo(OrderSymbol(), MODE_ASK), _Slippage, CLR_NONE)) Print("v128-2 > ", _Symbol, " > SELL -> ticket=", OrderTicket(), " -> 错误(关闭)#", GetLastError()); } } } } // 订单数量} //=++============================================== ================++= // 计算方向的订单数量int CountOrders(int cmd) {诠释 n = 0; for(int i = OrdersTotal() - 1; i >= 0 ; i--) { if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if((OrderSymbol() == _Symbol) && (OrderMagicNumber() == _Magic1 || OrderMagicNumber() == _Magic2) && (OrderType() == cmd) ) n++; } }返回(n); } //=++============================================== ================++= // 通过魔法搜索订单bool FindOrders(int magic) { for(int i = OrdersTotal() - 1; i >= 0 ; i--) { if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if( (OrderSymbol() == _Symbol) && (OrderMagicNumber() == magic) )返回(真); } }返回(假); } //=++============================================== ================++= // 用魔法计算出盈亏平衡水平无效止损_0(int from) {双赢点,出价,询价;布尔是;双 P3_buy, P3_sell; // for(int i = OrdersTotal() - 1; i >= 0 ; i--) { if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if(!( (OrderSymbol() == _Symbol) && (OrderMagicNumber() == _Magic1 || OrderMagicNumber() == _Magic2) )) 继续; // if(OrderType() == OP_BUY) {出价 = MarketInfo(_Symbol, MODE_BID);利润点 = (出价 - OrderOpenPrice()) / _Point;是 = 利润点 >= _StopLoss_0_Level + 来自; P3_buy = ND( OrderOpenPrice() + from * _Point ); // if( 是 && ( OrderStopLoss() == 0 || OrderStopLoss() < P3_buy ) ) { Print("v128-2 b4 >", _Symbol, " | ", _Timeframe, " -> Bid=", MarketInfo(_Symbol, MODE_BID), " | p/o=", OrderOpenPrice(), " | s/l=", OrderStopLoss(), " | P3_buy=", P3_buy, " | d=", _StopLoss_0_Level, " | Profitpoint=", 利润点); if(!OrderModify(OrderTicket(), OrderOpenPrice(), P3_buy, OrderTakeProfit(), 0, CLR_NONE)) Print("v128-2 b4 > ", _Symbol, " | ", _Timeframe, " -> BUY > ticket=", OrderTicket(), " > Error (breakeven) #", GetLastError()); } } //否则如果(订单类型()== OP_SELL) {询问 = MarketInfo(_Symbol, MODE_ASK);利润点 = (OrderOpenPrice() - 询价) / _Point;是 = 利润点 >= _StopLoss_0_Level + 来自; P3_sell = ND( OrderOpenPrice() - from * _Point ); // if( 是 && ( OrderStopLoss() == 0 || OrderStopLoss() > P3_sell ) ) { Print("v128-2 b4 >", _Symbol, " | ", _Timeframe, " -> Ask =", MarketInfo(_Symbol, MODE_ASK), " | p/o=", OrderOpenPrice(), " | s/l=", OrderStopLoss(), " | P3_sell=", P3_sell, " | d=", _StopLoss_0_Level, " | Profitpoint=", 利润点); if(!OrderModify(OrderTicket(), OrderOpenPrice(), P3_sell, OrderTakeProfit(), 0, CLR_NONE)) Print("v128-2 b4 > ", _Symbol, " | ", _Timeframe, " -> SELL -> ticket=", OrderTicket(), " > Error (breakeven) #", GetLastError()); } } } } } //=++============================================== ================++= // 用魔法计算追踪止损无效 TrailingStop(int from) {双赢点,出价,询价;双倍价格; // for(int i = OrdersTotal() - 1; i >= 0 ; i--) { if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if(!( (OrderSymbol() == _Symbol) && (OrderMagicNumber() == _Magic1 || OrderMagicNumber() == _Magic2) )) 继续; // if(OrderType() == OP_BUY) { if(_IsTrailingStopProfit) fromprice = OrderOpenPrice() + from * _Point;否则 fromprice = OrderStopLoss(); //出价 = MarketInfo(_Symbol, MODE_BID);利润点 = (bid - ND(fromprice)) / _Point; //如果(利润点 >= _TrailingStopLevel &&出价 > (OrderStopLoss() + (_TrailingStopLevel + _TrailingStopStep) * _Point) ) { Print("v128-2 v4 >", _Symbol, " | ", _Timeframe, " -> Bid=", MarketInfo(_Symbol, MODE_BID), " | p/o=", OrderOpenPrice(), " | s/l=", OrderStopLoss(), " | d=", _TrailingStopLevel, " |profitpoint=", 利润点); if(!OrderModify(OrderTicket(), OrderOpenPrice(), ND(bid - (_TrailingStopLevel) * _Point), OrderTakeProfit(), 0, CLR_NONE)) { Print("v128-2 v4 >", _Symbol, " | ", _Timeframe, " -> BUY > ticket=", OrderTicket(), " > Error (trailing stop) #", GetLastError()); } } } //否则如果(订单类型()== OP_SELL) { if(_IsTrailingStopProfit) fromprice = OrderOpenPrice() - from * _Point;否则 fromprice = OrderStopLoss(); //询问 = MarketInfo(_Symbol, MODE_ASK);利润点 = (ND(fromprice) - 询价) / _Point; //如果(利润点 >= _TrailingStopLevel &&询问 < (OrderStopLoss() - (_TrailingStopLevel + _TrailingStopStep) * _Point) ) { Print("v128-2 v4 >", _Symbol, " | ", _Timeframe, " -> Ask=", MarketInfo(_Symbol, MODE_ASK), " | p/o=", OrderOpenPrice(), " | s/l=", OrderStopLoss(), " | d=", _TrailingStopLevel, " |profitpoint=", 利润点); if(!OrderModify(OrderTicket(), OrderOpenPrice(), ND(ask + (_TrailingStopLevel) * _Point), OrderTakeProfit(), 0, CLR_NONE)) { Print("v128-2 v4 >", _Symbol, " | ", _Timeframe, " -> SELL > ticket=", OrderTicket(), " > Error (trailing stop) #", GetLastError()); } } } } } } //=++============================================== ================++= // 寻找局部底部。返回价格双 FindPriceMinMax(bool isUp) {整数移位 = 1;双倍价格 = 0, p0,p1,p2;而(价格== 0) { p0 = iCustom(_Symbol, _Timeframe, "ZigZag", _ZZ_ExtDepth, _ZZ_ExtDeviation, _ZZ_ExtBackstep, 0, shift); p1 = iCustom(_Symbol, _Timeframe, "ZigZag", _ZZ_ExtDepth, _ZZ_ExtDeviation, _ZZ_ExtBackstep, 1, shift); p2 = iCustom(_Symbol, _Timeframe, "ZigZag", _ZZ_ExtDepth, _ZZ_ExtDeviation, _ZZ_ExtBackstep, 2, shift); //Print("v128-2 >", _Symbol, " | ", _Timeframe, // " > sift=", shift, " | p0=", p0, " | p1=", p1, " | p2=", p2);如果(是向上) { if(p0 !=0 && p0 == p1) // 找到顶点价格 = p0; }别的{ if(p0 != 0 && p0 == p2) // 找到底部价格 = p0; }班次++; } //Print("v128-2 >", _Symbol, " | ", _Timeframe, // " -> return(price)=", price);回报(价格); } //================================================= ===================== // 从文件中读取变量。 // 如果文件不存在,则创建文件并将变量写入文件double _FileReadWriteDouble(字符串文件名,双值) { int h1 = FileOpen(文件名,FILE_BIN);如果(h1 > 0) {值 = FileReadDouble(h1, DOUBLE_VALUE);文件关闭(h1); }别的{ h1 = FileOpen(文件名, FILE_BIN|FILE_WRITE); FileWriteDouble(h1, value, DOUBLE_VALUE);文件关闭(h1); }返回(值); } //================================================= ===================== // 将变量写入文件void _FileWriteDouble(字符串文件名,双值) { int h1 = FileOpen(文件名, FILE_BIN|FILE_WRITE); FileWriteDouble(h1, value, DOUBLE_VALUE);文件关闭(h1); } 请帮助免费编写EA。5个不同的想法。 Any questions from newcomers Please help write EAs vitek2010 2017.01.04 21:46 #545 Vitalie Postolache:在你上面展示的代码中,引用的是当前的TF,那么我们在谈论什么?如果你指的是W1的M5,那么就这样写。如果你在当前的时间框架下工作,那么收盘价是在零条上浮动的,而在其余的时间--只有一个收盘价,而不是很多,你如何在一个值上建立直方图,我不明白。如果你想画一个图像,使用编辑框顶部的图标按钮,那里有很多有用的按钮,我建议你学习。我想问的是,如何在当前的时间框架内获得指标的 最大和最小读数。如果你认为我很懒,不想找照片,不是的。但我还是做不到。我在终端(Insta)的图表上点击右键--保存为图片--活动图表原样--转到MKL5(同样的终端图片显示在那里)--底线bbCode(我选择并复制代码),然后我在信息中插入这个代码,在我发送信息后,信息中应该有一个图片(这个论坛没有,只显示代码文本),我试着用 "图片 "按钮(Ctrl+Alt+l)来选择文件,下载的代码不能粘贴在这一行,没有截图你就不明白。 Vitalie Postolache 2017.01.04 22:05 #546 vitek2010:我问的是如何在当前的时间框架内获得指标的最大和最小读数,我举了截图作为例子。如果你认为我很懒,不想找照片,不是的。但我还是做不到。我在终端(Insta)的图表上点击右键--保存为图片--活动图表原样--转到MKL5(同样的终端图片显示在那里)--底线bbCode(我选择并复制代码),然后我在信息中插入这个代码,在我发送信息后,信息中应该有一个图片(这个论坛没有,只显示代码文本),我试着用 "图片 "按钮(Ctrl+Alt+l)来选择文件,下载的代码不能粘贴在这个图上,但没有截图你就不会明白。你可以插入一个链接,而不是本地计算机上的文件名,就在同一行中,在他们写文件名的地方,一切都可以工作。像这样也可以在信息中插入一个链接,但要有标签,在这个论坛上标签不起作用。 像这样。至于从一个较小的TF中获取价格,有CopyRates和类似的功能,可以单独获取每个价格。 它被复制到数组中,然后在循环中,将时间与较高TF的蜡烛时间进行比较,如果较低的蜡烛符合,那么价格就被计入指标中。 Mickey Moose 2017.01.04 23:03 #547 是否有办法在测试器中看到指标图,因为图中显示了我错过的东西 附加的文件: Tester11.gif 18 kb Vitalie Postolache 2017.01.04 23:07 #548 trader781: 你能看到测试器中的指标图吗,因为从图上看,我在那里错过了什么?在测试器中,有一个"打开图"按钮。我想知道它是用来做什么的?或 "可视化 "复选框。 Mickey Moose 2017.01.04 23:12 #549 Vitalie Postolache:在测试器中,有一个"打开图"按钮。我想知道它是用来做什么的?或 "可视化 "复选框。 我的意思是,当图表在滚动时,那里没有指数。 Vitalie Postolache 2017.01.04 23:28 #550 trader781: 我的意思是,虽然图表在滚动,但那里没有火鸡。 从来没有过。当你需要的时候,你用手去设置它们。测试要暂停,指标要放在图表上,然后你再旋转它。 1...484950515253545556575859606162...1953 新评论 您错过了交易机会: 免费交易应用程序 8,000+信号可供复制 探索金融市场的经济新闻 注册 登录 拉丁字符(不带空格) 密码将被发送至该邮箱 发生错误 使用 Google 登录 您同意网站政策和使用条款 如果您没有帐号,请注册 可以使用cookies登录MQL5.com网站。 请在您的浏览器中启用必要的设置,否则您将无法登录。 忘记您的登录名/密码? 使用 Google 登录
我还没有使用类、数组、宏和从Windows库导入。所有的时间都很充裕。
对于数组来说,这就是一种浪费。数组是很方便的。结构也是如此。其余的,是的,如果项目不复杂,就根本不可能使用。
我同意数组非常方便,没有数组你往往无法合理地编写一个程序。结构...我在网络程序中写课,没有它们真的不好,也不方便,特别是如果项目很大的话,但我不喜欢通常单页的专家顾问中的MQ。我已经用OOP写了所有关于open/closed的数据,开始使用并删除了所有的东西,用程序化风格重写并使用,在一个循环中写了所有东西。所以课程是为爱好者准备的。
请帮我添加最大未结订单数(MAXORders)
}
在你上面展示的代码中,引用的是当前的TF,那么我们在谈论什么?如果你指的是W1的M5,那么就这样写。
如果你在当前的时间框架下工作,那么收盘价是在零条上浮动的,而在其余的时间--只有一个收盘价,而不是很多,你如何在一个值上建立直方图,我不明白。
如果你想画一个图像,使用编辑框顶部的图标按钮,那里有很多有用的按钮,我建议你学习。
我想问的是,如何在当前的时间框架内获得指标的 最大和最小读数。
如果你认为我很懒,不想找照片,不是的。但我还是做不到。我在终端(Insta)的图表上点击右键--保存为图片--活动图表原样--转到MKL5(同样的终端图片显示在那里)--底线bbCode(我选择并复制代码),然后我在信息中插入这个代码,在我发送信息后,信息中应该有一个图片(这个论坛没有,只显示代码文本),我试着用 "图片 "按钮(Ctrl+Alt+l)来选择文件,下载的代码不能粘贴在这一行,没有截图你就不明白。
我问的是如何在当前的时间框架内获得指标的最大和最小读数,我举了截图作为例子。
如果你认为我很懒,不想找照片,不是的。但我还是做不到。我在终端(Insta)的图表上点击右键--保存为图片--活动图表原样--转到MKL5(同样的终端图片显示在那里)--底线bbCode(我选择并复制代码),然后我在信息中插入这个代码,在我发送信息后,信息中应该有一个图片(这个论坛没有,只显示代码文本),我试着用 "图片 "按钮(Ctrl+Alt+l)来选择文件,下载的代码不能粘贴在这个图上,但没有截图你就不会明白。
你可以插入一个链接,而不是本地计算机上的文件名,就在同一行中,在他们写文件名的地方,一切都可以工作。像这样
也可以在信息中插入一个链接,但要有标签,在这个论坛上标签不起作用。 像这样。
至于从一个较小的TF中获取价格,有CopyRates和类似的功能,可以单独获取每个价格。
它被复制到数组中,然后在循环中,将时间与较高TF的蜡烛时间进行比较,如果较低的蜡烛符合,那么价格就被计入指标中。你能看到测试器中的指标图吗,因为从图上看,我在那里错过了什么?
在测试器中,有一个"打开图"按钮。我想知道它是用来做什么的?
或 "可视化 "复选框。
在测试器中,有一个"打开图"按钮。我想知道它是用来做什么的?
或 "可视化 "复选框。
我的意思是,虽然图表在滚动,但那里没有火鸡。