포럼을 어지럽히 지 않도록 모든 초보자 질문. 프로, 놓치지 마세요. 너 없이는 아무데도 - 6. - 페이지 937

 
silachara :

파일 작업 방법을 배우기 시작했습니다. 핸들이라는 용어를 만났습니다. 코드를 작성한 후 질문이 생겼습니다.

첫 번째 파일 news.csv를 연 후 프로그램은 값 1을 filehandle 변수에 할당했습니다. 다음으로 프로그램은 두 번째 파일 news150901.csv를 열고 값 2를 filehandle 변수에 할당했습니다. 두 번째 파일을 열 때만 핸들 값. 즉, 첫 번째 열린 파일의 핸들 값을 죽였습니다. 저것들. 데이터/콘텐츠에 액세스하고 닫기 두 번째 파일만 가능합니까? 열린 파일 핸들을 저장하기 위해 단일 변수를 사용하는 것이 실수입니까? 여는 각 파일의 핸들에 대한 변수를 생성해야 합니까?

파일을 열면 "액세스 코드"인 핸들을 받았습니다. 닫을 때까지 다른 파일이 열려 있는지 여부에 관계없이 핸들을 통해 이 파일에 대해 작업할 수 있습니다.

추신: 파일을 닫는 것을 잊지 마십시오(이 예에서는 닫혀 있지 않습니다).

 

Excel에서 연구를 위한 스크립트가 필요합니다.
설명.
30일 동안 매일 8.00에서 12.00까지 csv 파일로 인쇄 이 기간의 양초 시가와 종가를 인쇄합니다. 기간 - 지표가 설정되지만 한 시간을 넘지 않아야 합니다. 지표 자체는 표시되지 않아야 합니다. 무엇이든 버퍼에 저장됩니다.

사이클을 올바르게 회전시키는 방법은 무엇입니까?

 extern int    DayMax     = 30 ;     //количество дней для печати
extern int    DayStart   = 1 ;       //начинаем с первого бара
extern int    HourStart  = 10 ;     //время старта внутри дня
extern int    HourEnd    = 12 ;     //время конца внутри дня
//+------------------------------------------------------------------+
//| Script program start function                                    |
//+------------------------------------------------------------------+
void OnStart ()
  {
//---
   int per= Period ();  
   if (per> 60 ) return ;   //если период больше часа , прекращаем работу скрипта
   double c_o= 0 ,ABS_o_c= 0 ;

  
       for ( int d=DayStart;d<=DayMax;d++) //перебираем дни от DayStart до DayMax, т.е с вчерашнего до 30
      {
           for ( int h= 0 ;h< 60 /per* 24 ;h++) //перебираем бары с нолевого до последнего в сутках учитывая ТФ
          {
             if (Time[h]>HourStart && Time[h]<HourEnd) //проверка промежутка времени
            {
               //данные для печати и печать
               c_o=(Close[h]-Open[h])* Point ;
               ABS_o_c= MathAbs (c_o);
               
               f_PrintToFile(DayOfWeek(), TimeToString ( TimeCurrent (), TIME_DATE | TIME_MINUTES ),Open[h],Close[h],c_o,ABS_o_c);
               Print (DayOfWeek(), TimeToString ( TimeCurrent (), TIME_DATE | TIME_MINUTES ),Open[h],Close[h],c_o,ABS_o_c);
            }
          }
      }      
  }
//+------------------------------------------------------------------+
// 1.  В файл                           
//+------------------------------------------------------------------+
 void f_PrintToFile( int    f_DayOfWeek= 0 ,
                           string f_TimeCurrent= "" , 
                           double f_Open= 0 ,
                           double f_Close= 0 ,
                           double f_c_o= 0 ,
                           double f_ABS_o_c= 0 )
{
   string fileName= StringConcatenate ( Symbol (), " M" , Period (), " Tyrimas" );
   string FileType= ".csv" ;
   int handle;
   handle= FileOpen (fileName+FileType, FILE_WRITE | FILE_READ , ";" );
   if (handle!= INVALID_HANDLE )
   {
       FileSeek (handle, 0 , SEEK_END );
       FileWrite (handle,f_DayOfWeek,f_TimeCurrent,f_Open,f_Close,f_c_o,f_ABS_o_c);
       FileClose (handle);
   }
}

이 주기는 아마도 하루의 시작을 이해하지 못하기 때문에 선이 의심스럽습니다. 그러나 그것은 단순히 0 막대에서 작동합니다.

 for ( int h= 0 ;h< 60 /per* 24 ;h++)

이해하도록 도와주세요.

 
차트의 인디케이터 창에 설정된 인디케이터에서 가격 차트의 개체를 제거하는 방법을 알려주십시오.
 
Leo59 :
차트의 인디케이터 창에 설정된 인디케이터에서 가격 차트의 개체를 제거하는 방법을 알려주십시오.

차트 창의 인덱스는 항상 0입니다.

 bool    ObjectDelete (
   long      chart_id,     // идентификатор графика
   string    object_name   // имя объекта
   );
 
rvc :


전체 페이지를 엉망으로 만들어서 죄송합니다.

그리고 코드를 제대로 붙이기 어렵습니다. 편집기에는 특별한 SRC 버튼이 있습니다.
 
Vinin :
그리고 코드를 제대로 붙이기 어렵습니다. 편집기에는 특별한 SRC 버튼이 있습니다.
찾지 못했습니다((
 
rvc :
찾지 못했습니다((

SRC 비디오 카메라 앞에서 코드를 삽입하십시오 !

 
вот получилось ))) так как можно ли исправить? вообщем нужно чтобы вместо stop loss выставлялся отложенник либо новая ставка увеличенного лота.
extern double       Lots =0.1;  //стартовый лот
extern double     Factor =2.0;  //множитель лота
extern int         Limit =5;    //ограничение количества умножений лота
extern int      StopLoss =100;  //уровень ограничения убытков
extern int    TakeProfit =100;  //уровень фиксации прибыли
extern int     StartType =0;    //тип стартового ордера, 0-BUY, 1-SELL
extern int         Magic =1000; //индивидуальный номер эксперта
//----
double lots_step;
//----
int ticket_buy;
int ticket_sell;
int lots_digits;
//+------------------------------------------------------------------+
//| expert initialization function                                   |
//+------------------------------------------------------------------+
int init()
  {
   ticket_buy=-1;
   ticket_sell=-1;
//----
   lots_step=MarketInfo(Symbol(),MODE_LOTSTEP);
//----
   if(lots_step==0.01)
      lots_digits=2;
//----
   if(lots_step==0.1)
      lots_digits=1;
//----
   if(lots_step==1.0)
      lots_digits=0;
//----
   for(int pos=OrdersTotal()-1;pos>=0;pos--)
      if(OrderSelect(pos,SELECT_BY_POS)==true)
         if(OrderMagicNumber()==Magic)
            if(OrderSymbol()==Symbol())
              {
               if(OrderType()==OP_BUY)
                 {
                  ticket_buy=OrderTicket();
                  break;
                 }
               //----
               if(OrderType()==OP_SELL)
                 {
                  ticket_sell=OrderTicket();
                  break;
                 }
              }
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| expert deinitialization function                                 |
//+------------------------------------------------------------------+
int deinit()
  {return(0);}
//+------------------------------------------------------------------+
//| expert start function                                            |
//+------------------------------------------------------------------+
int start()
  {
   double price;
   double lots;
   double lots_test;
//----
   int slip;
   int ticket;
   int pos;
//----
//----открыть стартовый ордер BUY
   if(StartType==0)
      if(ticket_buy<0)
         if(ticket_sell<0)
           {
            ticket=OpenBuy(Lots);
            //----
            if(ticket>0)
               ticket_buy=ticket;
           }
//----
//----открыть следующий ордер BUY при положительном профите ордера BUY
   if(ticket_buy>0)
      if(ticket_sell<0)
         if(OrderSelect(ticket_buy,SELECT_BY_TICKET)==true)
            if(OrderCloseTime()>0)
               if(OrderProfit()>0.0)
                 {
                  ticket=OpenBuy(Lots);
                  //----
                  if(ticket>0)
                     ticket_buy=ticket;
                 }
//----
//----открыть следующий ордер SELL при отрицательном профите ордера BUY
   if(ticket_buy>0)
      if(ticket_sell<0)
         if(OrderSelect(ticket_buy,SELECT_BY_TICKET)==true)
            if(OrderCloseTime()>0)
               if(OrderProfit()<0.0)
                 {
                  lots=NormalizeDouble(MathCeil((OrderLots()*Factor)/lots_step)*lots_step,lots_digits);
                  lots_test=Lots;
                  //----
                  for(pos=0;pos<Limit;pos++)
                     lots_test=NormalizeDouble(MathCeil((lots_test*Factor)/lots_step)*lots_step,lots_digits);
                  //----
                  if(lots_test<lots)
                     lots=Lots;
                  //----
                  ticket=OpenSell(lots);
                  //----
                  if(ticket>0)
                    {
                     ticket_sell=ticket;
                     ticket_buy=-1;
                    }
                 }
//----
//----обслуживание виртуальных стопов ордера BUY
   if(ticket_buy>0)
      if(OrderSelect(ticket_buy,SELECT_BY_TICKET)==true)
         if(OrderCloseTime()==0)
            if(OrderOpenPrice()+TakeProfit*Point<=MarketInfo(Symbol(),MODE_BID))
              {
               price=MarketInfo(Symbol(),MODE_BID);
               slip=MarketInfo(Symbol(),MODE_SPREAD)*2;
               return(OrderClose(ticket_buy,OrderLots(),price,slip,Blue));
              }
//----
   if(ticket_buy>0)
      if(OrderSelect(ticket_buy,SELECT_BY_TICKET)==true)
         if(OrderOpenPrice()-StopLoss*Point>=MarketInfo(Symbol(),MODE_BID))
            if(OrderCloseTime()==0)
              {
               price=MarketInfo(Symbol(),MODE_BID);
               slip=MarketInfo(Symbol(),MODE_SPREAD)*2;
               return(OrderClose(ticket_buy,OrderLots(),price,slip,Blue));
              }
//----
//----открыть стартовый ордер SELL
   if(StartType==1)
      if(ticket_buy<0)
         if(ticket_sell<0)
           {
            ticket=OpenSell(Lots);
            //----
            if(ticket>0)
               ticket_sell=ticket;
           }
//----
//----открыть следующий ордер SELL при положительном профите ордера SELL
   if(ticket_buy<0)
      if(ticket_sell>0)
         if(OrderSelect(ticket_sell,SELECT_BY_TICKET)==true)
            if(OrderCloseTime()>0)
               if(OrderProfit()>0.0)
                 {
                  ticket=OpenSell(Lots);
                  //----
                  if(ticket>0)
                     ticket_sell=ticket;
                 }
//----
//----открыть следующий ордер BUY при отрицательном профите ордера SELL
   if(ticket_buy<0)
      if(ticket_sell>0)
         if(OrderSelect(ticket_sell,SELECT_BY_TICKET)==true)
            if(OrderCloseTime()>0)
               if(OrderProfit()<0.0)
                 {
                  lots=NormalizeDouble(MathCeil((OrderLots()*Factor)/lots_step)*lots_step,lots_digits);
                  lots_test=Lots;
                  //----
                  for(pos=0;pos<Limit;pos++)
                     lots_test=NormalizeDouble(MathCeil((lots_test*Factor)/lots_step)*lots_step,lots_digits);
                  //----
                  if(lots_test<lots)
                     lots=Lots;
                  //----
                  ticket=OpenBuy(lots);
                  //----
                  if(ticket>0)
                    {
                     ticket_buy=ticket;
                     ticket_sell=-1;
                    }
                 }
//----
//----обслуживание виртуальных стопов ордера SELL
   if(ticket_sell>0)
      if(OrderSelect(ticket_sell,SELECT_BY_TICKET)==true)
         if(OrderCloseTime()==0)
            if(OrderOpenPrice()-TakeProfit*Point>=MarketInfo(Symbol(),MODE_ASK))
              {
               price=MarketInfo(Symbol(),MODE_ASK);
               slip=MarketInfo(Symbol(),MODE_SPREAD)*2;
               return(OrderClose(ticket_sell,OrderLots(),price,slip,Red));
              }
//----
   if(ticket_sell>0)
      if(OrderSelect(ticket_sell,SELECT_BY_TICKET)==true)
         if(OrderCloseTime()==0)
            if(OrderOpenPrice()+StopLoss*Point<=MarketInfo(Symbol(),MODE_ASK))
              {
               price=MarketInfo(Symbol(),MODE_ASK);
               slip=MarketInfo(Symbol(),MODE_SPREAD)*2;
               return(OrderClose(ticket_sell,OrderLots(),price,slip,Red));
              }
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| открыть ордер BUY                                                |
//+------------------------------------------------------------------+
int OpenBuy(double lots)
  {
   double price;
//----
   int slip;
//----
   price=MarketInfo(Symbol(),MODE_ASK);
   slip=MarketInfo(Symbol(),MODE_SPREAD)*2;
//----
   return(OrderSend(Symbol(),OP_BUY,lots,price,slip,0.0,0.0,"",Magic,0,Blue));
  }
//+------------------------------------------------------------------+
//| открыть ордер SELL                                               |
//+------------------------------------------------------------------+
int OpenSell(double lots)
  {
   double price;
//----
   int slip;
//----
   price=MarketInfo(Symbol(),MODE_BID);
   slip=MarketInfo(Symbol(),MODE_SPREAD)*2;
//----
   return(OrderSend(Symbol(),OP_SELL,lots,price,slip,0.0,0.0,"",Magic,0,Red));
  }
//+------------------------------------------------------------------+
 
사람들이 할 수 있는 것보다 도움이! 아니면 비현실적입니까?
 
초보 프로그래머가 보류 중인 주문을 삭제 하는 스크립트를 작성할 수 있도록 도와주세요. 모든 시장 포지션이 없고 보류 중인 매도 주문이 없는 경우 보류 중인 모든 매수 주문을 삭제해야 합니다.