订单选择功能问题

 

boopa26可以写订单发送代码,但不能写订单选择函数来关闭订单。想写订单选择函数来关闭订单,但没有for循环或while循环。


发送买入订单 的例子

if(OrdersTotal()==0)OrderSend(Symbol(),OP_BUY,.1,Ask,3,0,0,NULL,9,0,clrNONE)。


例子订单选择。boopa26不理解

OrderSelect(int index,int select,int pool)


什么是int index?

什么是int select?

什么是int pool?

订单选择是怎么做的?

 

你读过文件吗?

Parameters

票据

[in] 订单索引或订单票据,取决于第二个参数。

选择

[in] 选择标志。它可以是以下任何一个值。

SELECT_BY_POS - 订单池中的索引。
SELECT_BY_TICKET - 索引是订单票。

pool=MODE_TRADES

[in] 可选的订单池索引。当选择参数为SELECT_BY_POS时使用。 它可以是以下任何一个值。

MODE_TRADES (默认)- 从交易池中选择的订单(已开仓和挂单)。
MODE_HISTORY - 从历史库中选择的订单(关闭和取消的订单)。


 
 
Gumrai可以包括文件链接,只是在开玩笑。
 
bool  OrderSelect(
   int     index,            // index or order ticket
   int     select,           // flag
   int     pool=MODE_TRADES  // mode
   );

boopa26想关闭未结订单,所以boopa选择MODE_TRADES作为第三个参数


boopa26是做SELECT_BY_POS还是SELECT_BY_TICKET? boopa26不知道。

SELECT_BY_POS //index inside order pool,
SELECT_BY_TICKET //index is order ticket.
 

boopa26选择MODE_TRADES作为第三个参数

boopa26选择SELECT_BY_POSITION作为第二个参数。

boopa26选择订单索引作为第一个参数


例子

static int order_index;

if(OrderSelect(order_index,SELECT_BY_POSITION,MODE_TRADES)==1
 

https://docs.mql4.com/trading/orderclose

Boopa26如何在没有for循环或while循环的情况下,用if条件来关闭订单选择功能的未结订单?

文件中关闭订单需要找到订单票据,但boopa26的订单选择是为了找到订单位置而不是票据。

bool  OrderClose(
   int        ticket,      // ticket
   double     lots,        // volume
   double     price,       // close price
   int        slippage,    // slippage
   color      arrow_color  // color
   );

1.选择订单

2.关闭订单

不知道怎么做

 
//+------------------------------------------------------------------+
//|                                               Moving Average.mq4 |
//|                   Copyright 2005-2014, MetaQuotes Software Corp. |
//|                                              http://www.mql4.com |
//+------------------------------------------------------------------+
#property copyright   "2005-2014, MetaQuotes Software Corp."
#property link        "http://www.mql4.com"
#property description "Moving Average sample expert advisor"

#define  MAGICMA  20131111
//--- Inputs
input double Lots          =0.1;
input double MaximumRisk   =0.02;
input double DecreaseFactor=3;
input int    MovingPeriod  =12;
input int    MovingShift   =6;
//+------------------------------------------------------------------+
//| Calculate open positions                                         |
//+------------------------------------------------------------------+
int CalculateCurrentOrders(string symbol)
  {
   int buys=0,sells=0;
//---
   for(int i=0;i<OrdersTotal();i++)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false) break;
      if(OrderSymbol()==Symbol() && OrderMagicNumber()==MAGICMA)
        {
         if(OrderType()==OP_BUY)  buys++;
         if(OrderType()==OP_SELL) sells++;
        }
     }
//--- return orders volume
   if(buys>0) return(buys);
   else       return(-sells);
  }
//+------------------------------------------------------------------+
//| Calculate optimal lot size                                       |
//+------------------------------------------------------------------+
double LotsOptimized()
  {
   double lot=Lots;
   int    orders=HistoryTotal();     // history orders total
   int    losses=0;                  // number of losses orders without a break
//--- select lot size
   lot=NormalizeDouble(AccountFreeMargin()*MaximumRisk/1000.0,1);
//--- calcuulate number of losses orders without a break
   if(DecreaseFactor>0)
     {
      for(int i=orders-1;i>=0;i--)
        {
         if(OrderSelect(i,SELECT_BY_POS,MODE_HISTORY)==false)
           {
            Print("Error in history!");
            break;
           }
         if(OrderSymbol()!=Symbol() || OrderType()>OP_SELL)
            continue;
         //---
         if(OrderProfit()>0) break;
         if(OrderProfit()<0) losses++;
        }
      if(losses>1)
         lot=NormalizeDouble(lot-lot*losses/DecreaseFactor,1);
     }
//--- return lot size
   if(lot<0.1) lot=0.1;
   return(lot);
  }
//+------------------------------------------------------------------+
//| Check for open order conditions                                  |
//+------------------------------------------------------------------+
void CheckForOpen()
  {
   double ma;
   int    res;
//--- go trading only for first tiks of new bar
   if(Volume[0]>1) return;
//--- get Moving Average 
   ma=iMA(NULL,0,MovingPeriod,MovingShift,MODE_SMA,PRICE_CLOSE,0);
//--- sell conditions
   if(Open[1]>ma && Close[1]<ma)
     {
      res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,0,"",MAGICMA,0,Red);
      return;
     }
//--- buy conditions
   if(Open[1]<ma && Close[1]>ma)
     {
      res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,0,"",MAGICMA,0,Blue);
      return;
     }
//---
  }
//+------------------------------------------------------------------+
//| Check for close order conditions                                 |
//+------------------------------------------------------------------+
void CheckForClose()
  {
   double ma;
//--- go trading only for first tiks of new bar
   if(Volume[0]>1) return;
//--- get Moving Average 
   ma=iMA(NULL,0,MovingPeriod,MovingShift,MODE_SMA,PRICE_CLOSE,0);
//---
   for(int i=0;i<OrdersTotal();i++)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false) break;
      if(OrderMagicNumber()!=MAGICMA || OrderSymbol()!=Symbol()) continue;
      //--- check order type 
      if(OrderType()==OP_BUY)
        {
         if(Open[1]>ma && Close[1]<ma)
           {
            if(!OrderClose(OrderTicket(),OrderLots(),Bid,3,White))
               Print("OrderClose error ",GetLastError());
           }
         break;
        }
      if(OrderType()==OP_SELL)
        {
         if(Open[1]<ma && Close[1]>ma)
           {
            if(!OrderClose(OrderTicket(),OrderLots(),Ask,3,White))
               Print("OrderClose error ",GetLastError());
           }
         break;
        }
     }
//---
  }
//+------------------------------------------------------------------+
//| OnTick function                                                  |
//+------------------------------------------------------------------+
void OnTick()
  {
//--- check for history and trading
   if(Bars<100 || IsTradeAllowed()==false)
      return;
//--- calculate open orders by current symbol
   if(CalculateCurrentOrders(Symbol())==0) CheckForOpen();
   else                                    CheckForClose();
//---
  }
//+------------------------------------------------------------------+
移动平均线 专家顾问用于周期性平仓的订单
 

我认为 "boopa26 "需要做以下事情。

  1. 首先,"boopa26 "需要首先学习编码的基础知识(如C语言)。
  2. 然后,"boopa26 "需要阅读并遵循这本书/教程(尽管它是旧的和过时的)。
  3. 同时,"boopa26 "需要阅读整个文档,特别注意书/教程 中没有提到的MQL4更新
  4. 然后,"boopa26 "需要研究用户代码库中 的指标、专家顾问(EA)和脚本的几个代码例子。
  5. 然后,"boopa26 "可以开始制作他自己的,但非常简单的指标,并慢慢地在它们的基础上,直到完全能够理解和制作更复杂的指标。
  6. 然后,"boopa26 "可以开始制作他自己的,但非常简单的EA,并慢慢地以它们为基础,直到完全能够理解和制作更复杂的EA。

"boopa26 "还必须学习一个非常重要的课程,即 "boopa26 "不应该跳过所有必要的步骤,因为否则 "boopa26 "将只是在浪费大家的时间,而不是一个 "美丽的蛋糕",所有 "boopa26 "将拥有 "烧焦的木炭"。

 
FMIC:

我认为 "boopa26 "需要做以下事情。

  1. 首先,"boopa26 "需要首先学习编码的基础知识(如C语言)。
  2. 然后,"boopa26 "需要阅读并遵循这本书/教程(尽管它是旧的和过时的)。
  3. 同时,"boopa26 "需要阅读整个文档,特别注意书籍/教程 中没有提到的MQL4更新
  4. 然后,"boopa26 "需要研究用户代码库中 的几个指标、专家顾问(EA)和脚本的代码例子。
  5. 然后,"boopa26 "可以开始制作他自己的,但非常简单的指标,并慢慢地在它们的基础上,直到完全能够理解和制作更复杂的指标。
  6. 然后,"boopa26 "可以开始制作他自己的,但非常简单的EA,并慢慢地在此基础上发展,直到完全能够理解和制作更复杂的EA为止。

"boopa26 "还必须学习一个非常重要的课程,即 "boopa26 "不应该跳过所有必要的步骤,因为否则 "boopa26 "将只是在浪费大家的时间,而不是一个 "美丽的蛋糕",他所得到的将是 "烧焦的木炭"。

1.不需要C语言知识,MQL4是不同的功能。

2.已经读过书

3.已经阅读了文档

4.已经写好了代码

5.?

6.?

boopa26不浪费人们的时间

教boopa26烤木炭蛋糕的FMIC老师

FMIC木炭蛋糕课