📅 财经日历 📊 实时波动 📈 大盘云图 📶 行情走势 🆚 投机情绪 🚀 今日热点

    请教EA的编程问题!谢谢!

    2011-11-17 · 8020 阅读
    各位神仙,我想做一个简单的EA,但是不知道该如何入手,请各位指点一下,不胜感激!
      
      EA的思路如下:
      
      使用的指标:均线。
      
      开仓条件:
      D1:上一个K线开盘价低于均线,当前K线开盘价高于均线,视为信号,检查H4图。
          如果没有信号,监视D1,直至出现信号为止。
      
      H4:上一个K线开盘价低于均线,当前K线开盘价高于均线,视为信号,检查H1图。
          如果没有信号,监视H4,直至出现信号为止。
      
      H1:上一个K线开盘价低于均线,当前K线开盘价高于均线,视为信号,准备买入。
          如果没有信号,监视H1,直至出现信号为止。
      
      最后,在H1给出买入信号的时间点上,检查H4、D1,是否开盘价高于均线,如果是,则买入,如果不是则不操作。
      
      循环。
      
      以上是买单开仓条件,卖单的开仓条件为:上一个K线开盘价高于均线,当前K线开盘价低于均线,其余相同。
      
      持仓的状态不是持有多单,就是持有空单,不锁单。
      
      
      平仓条件:
      
      1  如果盈利点数未达到100点,止损在-150点。
      2  如果盈利点数达到100点,止损在0点;盈利点数达到200点,止损在100点;盈利点数达到300点,止损在200点;以此类推……
      3  如果出现相反信号,平仓,按新的信号开仓。
      
      资金管理:
      
      每笔交易所承担的风险不超过总资本的10%,最大同时开仓单数为3单。

    [ 本帖最后由 huangkong 于 2008-4-22 11:43 编辑 ]
    ""
    还没有人打赏,支持一下
    回复

    举报

     

    回答|共 27 个

    lramr LV6

    发表于 2012-11-22 02:18:00 | 显示全部楼层

    支持一下吧  

    wax87etz LV4

    发表于 2012-11-22 02:18:00 | 显示全部楼层

    不错,看看。  

    music LV5

    发表于 2012-11-22 02:18:00 | 显示全部楼层

    回帖是种美德.  

    悟空小宝 LV5

    发表于 2012-11-22 02:18:00 | 显示全部楼层

    晕  不信啊  

    天道无名 LV4

    发表于 2012-11-22 02:18:00 | 显示全部楼层

    楼主good  

    他们 LV5

    发表于 2012-11-22 02:18:00 | 显示全部楼层

    不错的东西  持续关注  

    西城威尔士 LV6

    发表于 2012-11-22 02:18:00 | 显示全部楼层

    慢慢来,呵呵  

    EA-fans LV4

    发表于 2012-11-22 02:18:00 | 显示全部楼层

    刚刚接触EA ,楼主请发份给我…  

    杨过 LV3

    发表于 2012-11-26 15:12:44 | 显示全部楼层

    1. //+------------------------------------------------------------------+
    2. //|                           Designed by OKwh, China               |
    3. //|                   Copyright 2007, OKwh Dxdcn                    |
    4. //|                                 http://blog.sina.com.cn/FXTrade |
    5. //+------------------------------------------------------------------+
    6. #property  copyright "Copyright 2007 , Dxd, China."
    7. #property  link      "http://blog.sina.com.cn/FXTrade ,  http://www.mql4.com/users/DxdCn"
    8. #define MAGICMA 200610011231
    9. //+------------------------------------------------------------------+
    10. //| 注意没有指标文件那些property                   |
    11. //+------------------------------------------------------------------+
    12. extern int whichmethod = 1;   //1~4 种下单方式  1 仅开仓, 2 有止损无止赢, 3 有止赢无止损, 4 有止赢也有止损
    13. extern double TakeProfit = 100;   //止赢点数
    14. extern   double StopLoss = 20;    //止损点数
    15. extern double MaximumRisk     = 0.3; //资金控制,控制下单量
    16. extern   int TP =100;

    17. extern   int maxOpen = 3;   //最多开仓次数限制
    18. extern   double maxLots = 0.1;   //最多单仓持仓量限制
    19. extern int bb = 0;       //非零就允许跟踪止赢

    20. int i, p2, xxx,p1, res;
    21. double Lots;
    22. datetime lasttime;       //时间控制, 仅当一个时间周期完成才检查条件
    23. int init()   //初始化
    24. {
    25. Lots = 1;
    26. lasttime = NULL;
    27. return(0);
    28. }
    29. int deinit() { return(0); } //反初始化
    30. //主程序
    31. int start()
    32. {
    33. CheckForOpen();    //开仓 平仓 条件检查 和操作
    34. if (bb>0)   CTP();   //跟踪止赢
    35. return(0);
    36. }
    37. //+------下面是各子程序--------------------------------------------+
    38. double LotsOptimized()   //确定下单量,开仓调用 资金控制
    39. {
    40. double lot=Lots;
    41. int   orders=HistoryTotal();   // history orders total
    42. int   losses=0;             // number of losses orders without a break
    43. //MarketInfo(Symbol(),MODE_MINLOT);     相关信息
    44. //MarketInfo(Symbol(),MODE_MAXLOT);
    45. //MarketInfo(Symbol(),MODE_LOTSTEP);
    46. lot=NormalizeDouble(MaximumRisk * AccountBalance()/AccountLeverage(),1);     //开仓量计算
    47. if(lot<0.1) lot=0.1;
    48. if(lot>maxLots) lot=maxLots;
    49. return(lot);
    50. }
    51.   
    52. //平仓持有的买单
    53. void CloseBuy()
    54. {
    55. if (OrdersTotal( ) > 0 )   
    56. {
    57.   for(i=OrdersTotal()-1;i>=0;i--)
    58.   {
    59.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
    60.   if(OrderType()==OP_BUY)
    61.   {
    62.     OrderClose(OrderTicket(),OrderLots(),Bid,3,White);
    63.     Sleep(5000);
    64.   }
    65.   }
    66. }
    67. }
    68. //平仓持有的卖单
    69. void CloseSell()
    70. {
    71. if (OrdersTotal( ) > 0 )   
    72. {
    73.   for(i=OrdersTotal()-1;i>=0;i--)
    74.   {
    75.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
    76.   if(OrderType()==OP_SELL)
    77.     {
    78.     OrderClose(OrderTicket(),OrderLots(),Ask,3,White);
    79.     Sleep(5000);
    80.     }
    81.   }
    82. }
    83. }
    84. //判断是否买或卖或平仓
    85. int buyorsell()   //在这个函数计算设置你的交易信号  这里使用MACD 和MA 做例子
    86. {
    87.   
    88. if()
    89.   return (1); // 买
    90. if()
    91.   return (-1); // 卖
    92. return (0); //不交易 }
    93. }

    94. int nowbuyorsell = 0;
    95. void CheckForOpen()
    96. {
    97. if (Time[0] == lasttime ) return; //每时间周期检查一次  时间控制
    98. lasttime = Time[0];
    99. nowbuyorsell = buyorsell(); //获取买卖信号

    100. if (nowbuyorsell == 1) //买 先结束已卖的
    101.   CloseSell();
    102. if (nowbuyorsell == -1) //卖 先结束已买的
    103.     CloseBuy();

    104. if (OrdersTotal( ) >= maxOpen) return ;   
    105. //如果已持有开仓次数达到最大,不做
    106. if (nowbuyorsell==0) return;   //不交易
    107. TradeOK();   //去下单交易
    108. }
    109. void TradeOK()   //去下单交易
    110. {
    111. int error ;
    112. if (nowbuyorsell == 1) //买
    113.   {
    114.     switch (whichmethod)
    115.     {
    116.     case 1:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,0,"",MAGICMA,0,Blue);break;
    117.     case 2:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,Ask-StopLoss*Point,0,"",MAGICMA,0,Blue); break;
    118.     case 3:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,Ask+TakeProfit*Point,"",MAGICMA,0,Blue);break;
    119.     case 4:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,Ask-StopLoss*Point,Ask+TakeProfit*Point,"",MAGICMA,0,Blue);break;
    120.     default : res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,0,"",MAGICMA,0,Blue);break;
    121.     }
    122.     if (res <=0)
    123.     {
    124.     error=GetLastError();
    125.     if(error==134)Print("Received 134 Error after OrderSend() !! ");         // not enough money
    126.     if(error==135) RefreshRates();   // prices have changed
    127.     }
    128.     Sleep(5000);
    129.     return ;   
    130.   }
    131. if (nowbuyorsell == -1) //卖
    132.   {
    133.     switch (whichmethod)
    134.     {
    135.     case 1:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,0,"",MAGICMA,0,Red); break;
    136.     case 2:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,Bid+StopLoss*Point,0,"",MAGICMA,0,Red); break;
    137.     case 3:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,Bid-TakeProfit*Point,"",MAGICMA,0,Red); break;
    138.     case 4:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,Bid+StopLoss*Point,Bid-TakeProfit*Point,"",MAGICMA,0,Red); break;
    139.     default : res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,0,"",MAGICMA,0,Red); break;
    140.     }
    141.     if (res <=0)
    142.     {
    143.     error=GetLastError();
    144.     if(error==134) Print("Received 134 Error after OrderSend() !! ");         // not enough money
    145.     if(error==135) RefreshRates();   // prices have changed
    146.     }
    147.     Sleep(5000);
    148.     return ;   
    149.   }
    150. }
    151. void CTP()   //跟踪止赢
    152. {
    153. bool bs = false;
    154. int yz;

    155. for (int i = 0; i < OrdersTotal(); i++)
    156. {
    157.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
    158.   if (OrderType() == OP_BUY)
    159.   {
    160.   yz=(Bid - OrderOpenPrice())/Point/TP;
    161.   {
    162.   if(yz>0  &&  OrderStopLoss()<OrderOpenPrice()+(yz-1)*TP*Point)
    163.   
    164.   bs=OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()+(yz-1)*TP*Point , OrderTakeProfit(),0, Green);
    165.   }
    166.   }
    167.    
    168.   else if (OrderType() == OP_SELL)
    169.   {
    170.   yz=(OrderOpenPrice()- Ask)/Point/TP;
    171.   {
    172.   if(yz>0  &&  OrderStopLoss()>OrderOpenPrice()-(yz-1)*TP*Point)
    173.   bs=OrderModify(OrderTicket(), OrderOpenPrice(),OrderOpenPrice()-(yz-1)*TP*Point , OrderTakeProfit(),0, Green);  }
    174.   }
    175. }
    176. }
    复制代码
    123下一页
    您需要登录后才可以回帖 登录 | 注册

    提醒: 禁止引战、谩骂、灌水内容

    微信二维码

    有问题联系客服