2013年08月01日
第14回 月足チャート
MT4からデータを取得して月足チャートを表示します。
日足や週足と同様です。
(1) MT4のカスタムインディケータ
月足用に下記のカスタムインディケータ MNCSV28 を作ります。
//*******************************************************************
//
// MNCSV28
//
// CopyRight 2013 VBAFAN.
//
//*******************************************************************
#property indicator_chart_window
//---- input parameters
extern int OutputBars = 1000;
int timecounter=0;
//*******************************************************************
// init
//*******************************************************************
int init()
{
     quote_write();
     return(0);
}
//*******************************************************************
// start
//*******************************************************************
int start()
{
     if (Minute()==timecounter) return(0);
     timecounter=Minute();
     quote_write();
     return(0);
}
//*******************************************************************
// quote_write
//*******************************************************************
int quote_write()
{
     datetime dt;
     bool flag;
     string str;
     Comment("start");
     dt=outputCSV("USDJPY");
     flag=true;
     if (outputCSV("EURJPY")!=dt) flag=false;
     if (outputCSV("GBPJPY")!=dt) flag=false;
     if (outputCSV("AUDJPY")!=dt) flag=false;
     if (outputCSV("NZDJPY")!=dt) flag=false;
     if (outputCSV("CHFJPY")!=dt) flag=false;
     if (outputCSV("CADJPY")!=dt) flag=false;
     if (outputCSV("EURUSD")!=dt) flag=false;
     if (outputCSV("GBPUSD")!=dt) flag=false;
     if (outputCSV("AUDUSD")!=dt) flag=false;
     if (outputCSV("NZDUSD")!=dt) flag=false;
     if (outputCSV("USDCHF")!=dt) flag=false;
     if (outputCSV("USDCAD")!=dt) flag=false;
     if (outputCSV("EURGBP")!=dt) flag=false;
     if (outputCSV("EURAUD")!=dt) flag=false;
     if (outputCSV("EURNZD")!=dt) flag=false;
     if (outputCSV("EURCHF")!=dt) flag=false;
     if (outputCSV("EURCAD")!=dt) flag=false;
     if (outputCSV("GBPAUD")!=dt) flag=false;
     if (outputCSV("GBPNZD")!=dt) flag=false;
     if (outputCSV("GBPCHF")!=dt) flag=false;
     if (outputCSV("GBPCAD")!=dt) flag=false;
     if (outputCSV("AUDNZD")!=dt) flag=false;
     if (outputCSV("AUDCHF")!=dt) flag=false;
     if (outputCSV("AUDCAD")!=dt) flag=false;
     if (outputCSV("NZDCHF")!=dt) flag=false;
     if (outputCSV("NZDCAD")!=dt) flag=false;
     if (outputCSV("CADCHF")!=dt) flag=false;
     str=TimeToStr(dt,TIME_DATE)+" "+TimeToStr(dt,TIME_MINUTES)+" finished";
     if (flag) str=str+" All updated";
     Comment(str);
     Print(str);
     return(0);
}
//*******************************************************************
// outputCSV
//*******************************************************************
datetime outputCSV(string symbol)
{
     int handle;
     bool ret;
     handle=FileOpen(symbol+PERIOD_MN1+".csv",FILE_CSV|FILE_WRITE,',');
     if(handle<1) return(0);
     for(int i=0;i < OutputBars;i++)
     {
       ret = FileWrite(handle,
       TimeToStr(iTime(symbol,PERIOD_MN1,i),TIME_DATE),
       TimeToStr(iTime(symbol,PERIOD_MN1,i),TIME_MINUTES),
       iOpen(symbol,PERIOD_MN1,i),
       iHigh(symbol,PERIOD_MN1,i),
       iLow(symbol,PERIOD_MN1,i),
       iClose(symbol,PERIOD_MN1,i),
       iVolume(symbol,PERIOD_MN1,i) );
       if(ret<1) return(0);
     }
     FileClose(handle);
     return(iTime(symbol,PERIOD_MN1,0));
}
MT4から月足のCSVファイル取得するインディケータです。取得する通貨ペアは主要通貨ペア28種類です。上記のコードをコピーしてMT4フォルダ下の experts フォルダの indicators フォルダにファイル名 MNCSV28.mq4 で保存して下さい。
(2) カスタムインディケータのコンパイル
MT4のツールメニューのメタエディターをクリックするとメタエディターが起動します。
file メニューから MNCSV28.mq4 を open して下さい。
メニューの compile ボタンをクリックして下さい。
0 error(s),0 warning(s) と表示されればOKです。
terminal ボタンを押すとメタエディターが終了します。
コンパイル後の実行可能ファイル名は MNCSV28.ex4 になります。ソースファイルと同じフォルダに作成されます。
(3) チャートへカスタムインディケータを貼り付ける
コンパイルが完了するとナビゲーターのカスタムインディケータに MNCSV28 が表示されます。いずれか1つのチャートにドラッグして貼り付けて下さい。月足チャートでなくともかまいません。
以上でMT4の準備作業は終了です。
(4) プロパティシートの設定
B2セルの足種類を月足にして下さい
(5) MT4を起動します
(6) MT4の画面でCSVファイル取得完了のメッセージが表示されるのを待ちます
MNCSV28 ... initialized の次に
MNCSV28 ... finished All updated が表示されればOKです。
MT4のカスタムインディケータをセットしたチャートにも finished All updated が表示されます。カスタムインディケータはどれか1つのチャートにセットすれば必要な通貨ペアのCSVをすべてを取得することができます。
(7) エクセルでデータ更新ボタンを押します
A3セルのデータ更新ボタンを押すとデータの取込を行い、月足チャートを表示します。
エクセルファイルです。
    ダウンロード
前へ   次へ
【このカテゴリーの最新記事】
-
no image