MQL4、MQL5に関する初心者からの質問、アルゴリズムやコードに関するヘルプ、ディスカッションなど。 - ページ 379

 
Taras Slobodyanik:

ゼロはないだろ、どっかで失敗してるんだろ。


どちらのプリンターも同じ値を出すのですか?

なぜなら、私のコードにはPrint関数が なく、これらの行は次々と続くので、値は何も変わらないからです。

しかし、Varは0を与え、Codeは必要な値を与えます。

 
LuckySith:

でも、割り当てている値をすぐに出力しています。そのため、基本的には以下のようなコードになります。

a=bです。

印刷する(a)。

プリント(b)。

しかし、aは0に等しく、bは正しくプリントされる

整数型変数に実数値を代入する際に、int a と double b>0 かつ b<1 であれば、端数部分を 切り捨てることが可能です

 
STARIJ:

整数型変数に実数値を代入する際、int a と double b>0 かつ b<1 の場合、端数部分を 切り捨てることが可能です


bは1より大きい はるかに大きい

a は double 型の配列です。

 

問題は解決されました。

次のような方法で配列を作成しました。


double line[];

このオプションでは、line[0]=xを代入しても、null要素が空になるように見えました。


と書いたら


ダブルライン[20]。


すべて正常に動作しています。最初のケースでは、境界のない配列を作成しただけでしたが、この違いは何でしょうか?

 
LuckySith:

問題は解決されました。

次のような方法で配列を作成しました。


double line[];

このオプションでは、line[0]=xを代入しても、null要素が空になるように見えました。


と書いたら


ダブルライン[20]。


すべて正常に動作しています。最初のケースでは、境界のない配列を作成しただけでしたが、この違いは何でしょうか?

動的な配列を 作成したわけですが、そのサイズは自分で設定・制御する必要があります。

 
Artyom Trishkin:

動的な配列を 作成しましたが、サイズを自分で設定し、制御する必要があります。

property strict指示文は、このエラーの発見を早める。プログラムは次のようなメッセージで終了します:'C.mq4' (31,32) の配列は範囲外です。
 

誰も助けてくれないのか?私にとっての行き止まりは、ここに 記されてファイルに書き込む 必要のない、他の解決策があるのでしょうか?

ソフトウェアのコードはこちらhttps://www.mql5.com/ru/forum/160683/page378#comment_6053255

Любые вопросы новичков по MQL4, помощь и обсуждение по алгоритмам и кодам
Любые вопросы новичков по MQL4, помощь и обсуждение по алгоритмам и кодам
  • 2017.11.14
  • www.mql5.com
В этой ветке я хочу начать свою помощь тем, кто действительно хочет разобраться и научиться программированию на новом MQL4 и желает легко перейти н...
 
LRA:

ファイルからのデータによる指標-検索でこの行を入力し、見つけた


ファイルからデータを取り出すには、まずファイルへの記入が必要です。

 

痛っ...良い人たちだ!助けて!お願いプログラミングを勉強しています。あなたの協力がなければ、デッドロックになる。

インジケーターのデータをファイルに書き込んで、後でインジケーターを作るのに使おうとしているのですが。この指標は、現在のバーの正のティックのボリュームと負のティックのボリュームの差に基づいた線で描画されます。

MQL4 Referenceを使用して、データ配列をファイルにアップロードする方法についての情報を受け取りました。その結果、私はエラーだらけのコードを手に入れた。エラーの本質がわからないし、だいたい参考書のヒントを正しく使えていなかったりする。どなたか助けてください。

input string             InpFileName="111.csv";      // Имя файла 
input string             InpDirectoryName="Data";     // Имя каталога 

datetime Время=0;   // Время прошлого бара
double Bid1;
double   Buf_1[];
// double ExtBuffer;
long V1; // объем для текущего тика вверх
long V2; // накопленный объем для всех тиков вверх текущего бара
long V3; // объем текущего тика вниз
long V4; // накопленный объем для всех тиков вниз для текущего бара
long V5;  // отрицательные и положительные iVolume нарастающим итогом


void OnInit()
{
   IndicatorDigits(0);
   SetIndexBuffer(0,Buf_1);
   //SetIndexBuffer(1,Buf_2);
   Bid1=Bid;
   V5 = 0;
    
}
 
 
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int OnCalculate(const int rates_total,
                const int prev_calculated,
                const datetime &time[],
                const double &open[],
                const double &high[],
                const double &low[],
                const double &close[],
                const long &tick_volume[],
                const long &volume[],
                const int &spread[])
{
   datetime Вр=Time[0];   // Время текущего бара
   if(Вр>Время)           // Если новый бар
   {
      Время=Вр;           // Запомнить
//      Buf_1[0]=0;         // и обнулить последний элемент буфера
   }
   
   datetime date_Buf_1; // массив дат индикатора 
   datetime time_Buf_1; // массив времени 
// --- считаю объем для положительных и отрицательных тиков      
   if(Bid >= Bid1) 
{
   if(Bid > Bid1) // если тик положительный..
{   
   V1 = iVolume(NULL, 0, 0); // если повышающий цену тик, то находим его объем
   V2 = V1 + V2;
}
  else
{
   V1 = 0;                // если Bid1 = Bid2, т.е. изменение цены = 0, то iVolume этого тика присваиваем 0;
   V2 = V1 + V2;      
}               
}              
   else 
{
   V3 = iVolume(NULL, 0, 0); // если понижающий цену тик 
   V4 = V3 + V4;             // то находим его объем  
}
  
   V5 = V2-V4;               // определяем разницу (дельту) между объемами положительных и отрицательных тиков
   Bid1=Bid;
   Buf_1 [0] = V5; // в буфер сгружаем  дельту

//   ExtBuffer = Buf_1 [0];
//   double macurrent=iMAOnArray(ExtBuffer,0,5,0,MODE_LWMA,0); 

// запись в файл данных буфера

//--- установим для массивов признак таймсерии 
   ArraySetAsSeries(Buf_1,true); 
   ArraySetAsSeries(date_Buf_1,true);
   
//--- скопируем таймсерию 
   int copied=CopyTime(NULL,0,0,0,date_Buf_1);    

//--- подготовим массив Buf_1 
   ArrayResize(Buf_1,copied); 
//--- скопируем значения линии индикатора  
   for(int i=0;i<copied;i++) 
     { 
      Buf_1[i]= V5; 
     } 
//--- откроем файл для записи значений индикатора 
   ResetLastError(); 
   int file_handle=FileOpen(InpDirectoryName+"//"+InpFileName,FILE_READ|FILE_WRITE|FILE_CSV); 
   if(file_handle!=INVALID_HANDLE) 
     { 
      PrintFormat("Файл %s открыт для записи",InpFileName); 
      PrintFormat("Путь к файлу: %s\\Files\\",TerminalInfoString(TERMINAL_DATA_PATH)); 
      //--- сначала запишем значения индикатора 
      FileWrite(file_handle,Buf_1); 
      //--- запишем время и значения в файл 
      for(int i=0;i<Buf_1;i++) 
         FileWrite(file_handle,time_Buf_1[i],Buf_1[i]); 
      //--- закрываем файл 
      FileClose(file_handle); 
      PrintFormat("Данные записаны, файл %s закрыт",InpFileName); 
     } 
   else 
      PrintFormat("Не удалось открыть файл %s, Код ошибки = %d",InpFileName,GetLastError()); 
  }
   
  return(rates_total);
}
 
YarTrade: インジケーターのデータをファイルに書き込んで、後でインジケーターを構築するのに使えるようにしようとしています。このインジケータは、現在のバーの正のティックのボリュームと負のティックのボリュームの差のデータに基づいて、ラインとして構築されています。

もし、あなたのコードを見た人が、すぐにエラーを見つけられると思ったら、それは間違いです。コンパイラはエラーを探します。プログラムテキストは整形する必要があります。MetaEditorにはそのためのスタイリング ツールがあります。別のスタイルがお好みなら、たとえばAStyle.exeプログラムをお使いください。スタイリング後、すぐにプログラム1)に余分な閉じ括弧があることがわかります。2)宣言された変数: datetime date_Buf_1; // インジケータ日付配列 - これが配列であるためには、[size]か動的配列の[]を指定し、サイズをArrayResizeに 設定しなければならないようです。そして、これは配列を使用する前に行う必要があります - それについては、上記の記事を参照してください。3) FileOpen(InpDirectoryName+"//"+InpFileName - スティックを他の方向に傾ける必要があるように思えます。また、InpDirectoryName+"//"は使わない方がよいでしょう - いずれにせよ、ファイルはFilesフォルダで見つかります。

on line: int copied=CopyTime(NULL,0,0,0,date_Buf_1); コンパイラは怒って、start=end=0 number=0 とする。

Стилизатор - Работа с исходным кодом - Разработка программ - Справка по MetaEditor
Стилизатор - Работа с исходным кодом - Разработка программ - Справка по MetaEditor
  • www.metatrader5.com
Данная функция предназначена для оформления исходного кода в соответствии с рекомендуемым стандартом. Это позволяет сделать код более читаемым, выглядящем профессионально. Грамотно оформленный код гораздо проще анализировать в последующем как его автору, так и другим пользователям. Для того чтобы запустить стилизатор, необходимо выполнить...