一、文件放置說明
¤ 指標的mq4、ex4文件復制至experts目錄的indicators子目錄下
¤ EA自動交易的mq4、ex4文件復制至experts目錄下
¤ tpl文件為模板文件,復制至templates目錄下
¤ DLL文件為庫文件,復制至experts目錄的libraries子目錄下
¤ SET文件為設置文件,復制至experts目錄的presets子目錄下
¤ pdf、txt、doc文件為說明文檔,可直接打開閱讀
二、EA使用方法
作為外匯交易的延伸,使用智能交易系統(EA)代替人工交易似乎成為一種新的潮流,那麼如何在MT4裡使用EA智能交易系統呢?
1、首先,當然你得要有一個EA,而且必須是以ex4為擴展名的,如果是只有mq4文件的話,請用MetaTrader自帶的編輯器MetaEditor打開,將mq4通過編譯(compile),並且要不出現錯誤,才能在原存放mq4的文件夾下面得到一個同名的ex4文件。www.emoneybtc.com
2、把這個ex4後綴的文件復制到MetaTrader 4所在的文件夾下面的experts文件夾下,比如:D:MetaTraderexperts,關閉並重新打開MetaTrader 4。
3、在“導航”下面的“智能交易系統”下面右鍵點擊你想要使用的EA,這裡以10點盈利系統舉例,點“附加到圖表”,如:
4、將會出現下面的彈出窗口:
特別要注意這裡的選擇,如果沒有鉤選“允許實時自動交易”,那麼你的智能系統就不會自動交易。
5、在自動成交方面,MT還有一個總開關,就是“工具”菜單下面的“選項”中:
6、還有一個地方必須選擇“啟動”:
上圖最後面的變成這樣的就是已經啟動了智能交易系統。
7、在完成了上面的所有設置後,看看你的圖表的右上角一定會出現你的智能交易系統的文件名和一個笑臉。
出現這樣就算是當前的圖表已經啟用了智能交易系統了。這時,你就可以去花天酒地等著你的智能交易系統為你的交易賬戶上面增加資金了。
8、如果你要停止你的智能交易系統,最好的辦法是點擊這個圖上面的“智能交易”圖標
不過這樣一來,你的所有圖表上面的智能交易就全部停止了。所有圖表右上角的笑臉都變成了叉叉:
如果只要停止當前圖表上面的EA,你應該按 F7 鍵,就會彈出如下的窗口:
點擊將“允許實時自動交易”前面的鉤去掉,然後確定,這樣就使當前圖表上面的EA停止了。圖表上面會出現“哭喪的臉”:
而如果要完全將當前圖表上面的EA消除,先右鍵點擊圖表區域,會出現:
點擊“智能交易系統”,然之後點擊“消除”,這個EA就會從當前圖表上面刪除,圖表的右上角就會什麼都沒有了。
四、附:EA的簡介
EA 即 Expert Advisors 的英文縮寫
中文意思專家顧問,俗稱智能交易系統,就是由電腦模擬交易員的下單操作進行機器自動交易的過程。
一>、人工操盤過程
下面我們就以MT4外匯客戶端為例,首先來分析一個外匯交易員手工進行外匯交易的操作過程:其步驟如下:
1. 打開外匯交易客戶端,選定一種貨幣對圖表;
2. 監視該貨幣對的K線趨勢圖,俗稱盯盤,尋找開倉或者是平倉的時機,即開倉或者是平倉的條件。
3. 如果條件滿足,進行下單開倉(做多或者做空)或者平倉。
4. 重復第二步,繼續盯盤,假定第二步是開倉,就是尋找平倉的條件。
5. 如果平倉的條件滿足,進行平倉操作,計算盈虧核算。完成一次交易的循環。
6. 若繼續交易,重復2->3->4->5步。
7. 若不進行交易,退出外匯客戶端。
三>、 相關MQL語言知識
為了實現機器操作,再來看看所需的MQL4語言的相關知識:
1. 掌握MQL4語言的基本語法和程序的構成,及運行流程
有關語法部分,請讀者參看相關的資料,這裡略去。
關於程序的構成,對於一個智能交易系統EA程序來說:主要由三個函數構成分別是:
init():初始化函數,負責程序變量及數據初始輸入;只在程序調入時執行一次,一般不用重寫內容。
deinit():反初始化函數,負責程序退出時,將數據從內存中清除;只在程序退出時,執行一次,一般不用重寫內容。
start():開始函數,也即程序的主函數,負責EA程序的全部交易執行過程,實際上他是一個EA的交易管理與執行函數。每隔一定時間,一般幾秒之內,執行一次,就是循環執行,直到程序退出時終止。
運行流程:啟動EA後,程序的INTI()開始執行一次,-->然後 START()循環執行--->最後退出EA時deinit()執行一次。
2. mql4中與交易相關的交易函數:
開倉函數:
int OrderSend( string symbol, int cmd, double volume, double price, int slippage, double stoploss, double takeprofit, void comment, void magic, void expiration, void arrow_color)
這個功能主要應用於開倉位置和掛單交易。
參量:
symbol - 交易貨幣對。
cmd - 購買方式。
volume - 購買手數。
price - 收盤價格。
slippage - 最大允許滑點數。
stoploss - 止損水平。
takeprofit - 贏利水平。
comment - 注解文本。
magic - 定單指定碼。可以作為用戶指定識別碼使用。
expiration - 定單有效時間(只限掛單)。
arrow_color - 圖表上箭頭顏色。如果參量丟失或存在CLR_NONE價格值不會在圖表中畫出。
平倉函數:
bool OrderClose( int ticket, double lots, double price, int slippage, void Color)
對定單進行平倉操作。如果函數成功,返回的值是真實的。如果函數失敗,返回的值是假的。獲得詳細錯誤信息,請查看GetLastError()函數。
參量:
ticket - 定單編號。
lots - 手數。
price - 收盤價格。
slippage - 最高劃點數。
Color - 圖表中標記顏色。如果參量丟失,CLR_NONE值將不會在圖表中畫出。
定單修改函數:
bool OrderModify( int ticket, double price, double stoploss, double takeprofit, datetime expiration, void arrow_color)
對於先前的開倉或掛單進行特性修改。如果函數成功,返回的值為 TRUE。如果函數失敗,返回的值為FALSE。獲得詳細的錯誤信息,查看 GetLastError()函數。
參量:
ticket - 定單編號。
price - 收盤價格
stoploss - 新止損水平。
takeprofit - 新贏利水平。
expiration - 掛單有效時間。
arrow_color - 在圖表中允許對止損/贏利顏色進行修改。如果參量丟失或存在CLR_NONE 值,在圖表中將不會顯示。
五、源碼的交易流程分析
下面的源碼是一個基於移動平均線的智能交易系統的代碼 ,整個程序非常簡潔但EA的功能又非常齊全,實現了完全由電腦自動下單和平倉,整個程序只用了一個START()函數來實現。
程序代碼分析
參看代碼中的相關注釋
//+------------------------------------------------------------------+
//---- input parameters
extern double TakeProfit = 20;
extern double StopLoss = 30;
extern double Lots = 2;
extern double TrailingStop = 50;
extern int ShortEma = 5;
extern int LongEma = 60;
//+------------------------------------------------------------------+
//| expert initialization function |
//+------------------------------------------------------------------+
int init()
{
//----
//----
return (0);
}
//+------------------------------------------------------------------+
//| expert deinitialization function |
//+------------------------------------------------------------------+
int deinit()
{
//----
//----
return (0);
}
//+------------------------------------------------------------------+
//| expert start function |
//+------------------------------------------------------------------+
int start()
{
int cnt, ticket, total;
double SEma, LEma;
//----
if (Bars < 100)
{
Print("bars less than 100");
return (0);
}
//----
if (TakeProfit < 10)
{
Print("TakeProfit less than 10");
return (0); // check TakeProfit
}
//----
SEma = iMA(NULL, 0, ShortEma, 0, MODE_EMA, PRICE_CLOSE, 0);
LEma = iMA(NULL, 0, LongEma, 0, MODE_EMA, PRICE_CLOSE, 0);
//----
static int isCrossed = 0;
isCrossed = Crossed(LEma, SEma);
//----
total = OrdersTotal();
if (total < 1)
{
if (isCrossed == 1) // 滿足空倉條件,開空倉
{
ticket = OrderSend(Symbol(), OP_SELL, Lots, Bid, 3, Bid + StopLoss * Point,
Bid - TakeProfit * Point, "EMA_CROSS", 12345, 0, Green);
if (ticket > 0)
{
if (OrderSelect(ticket, SELECT_BY_TICKET, MODE_TRADES))
Print("SELL order opened : ", OrderOpenPrice());
} else
Print("Error opening SELL order : ", GetLastError());
return (0);
}
if (isCrossed == 2) // 滿足多倉條件,開多倉
{
ticket = OrderSend(Symbol(), OP_BUY, Lots, Ask, 3, Ask - StopLoss * Point,
Ask + TakeProfit * Point, "EMA_CROSS", 12345, 0, Red);
if (ticket > 0)
{
if (OrderSelect(ticket, SELECT_BY_TICKET, MODE_TRADES))
Print("BUY order opened : ", OrderOpenPrice());
} else
Print("Error opening BUY order : ", GetLastError());
return (0);
}
return (0);
}
//---- 訂單修改,實現動態止盈止損跟蹤
for (cnt = 0; cnt < total; cnt++)
{
OrderSelect(cnt, SELECT_BY_POS, MODE_TRADES);
if (OrderType() <= OP_SELL && OrderSymbol() == Symbol())
{
if (OrderType() == OP_SELL) // long position is opened
{
// check for trailing stop
if (TrailingStop > 0)
{
if (Bid - OrderOpenPrice() > Point * TrailingStop)
{
if (OrderStopLoss() < Bid - Point * TrailingStop)
{
OrderModify(OrderTicket(), OrderOpenPrice(),
Bid - Point * TrailingStop,
OrderTakeProfit(), 0, Green);
return (0);
}
}
}
} else // go to short position
{
// check for trailing stop
if (TrailingStop > 0)
{
if ((OrderOpenPrice() - Ask) > (Point * TrailingStop))
{
if ((OrderStopLoss() > (Ask + Point * TrailingStop)))
{
OrderModify(OrderTicket(), OrderOpenPrice(),
Ask + Point * TrailingStop,
OrderTakeProfit(), 0, Red);
return (0);
}
}
}
}
}
}
//----
return (0);
}
//+------------------------------------------------------------------+
// 移動平均線多空條件判斷,
int Crossed(double line1, double line2)
{
static int last_direction = 0;
static int current_direction = 0;
//Don't work in the first load, wait for the first cross!
static bool first_time = true;
if (first_time == true)
{
first_time = false;
return (0);
}
//----
if (line1 > line2)
current_direction = 2; //up 多頭市場 上穿做多
if (line1 < line2)
current_direction = 1; //down 空頭市場 下穿做空
//----
if (current_direction != last_direction) //changed 多空改變 {
last_direction = current_direction;
return (last_direction);
else return (0); //not changed
}
六、本文結論
從以上的分析,可以知道,所謂EA,就是由電腦模擬交易員的下單操作進行機器交易的過程, 具體步驟如下:
1. 當用戶打開外匯客戶端程序後,由客戶端程序調入用戶在系統內已預置好的EA交易系統程序。
2. 當EA程序啟動後便開始對圖表中貨幣對的K線趨勢圖,進行監視,尋找開倉的條件;
3. 如果條件滿足,進行下單開倉(做多或者做空);
4. 重復第二步,繼續盯盤,假定第二步是開倉,就是尋找平倉的條件。
5. 如果平倉的條件滿足,進行平倉操作,計算盈虧核算。完成一次交易的循環。
6. 若繼續交易,EA重復2->3->4->5步。
7. 用戶若不想讓EA進行交易,可通過相關菜單操作設置禁用EA,或者退出外匯客戶端。
外_匯_邦 WaiHuiBang.com導讀:在數字廣告市場中,廣告主每年因為機器人無效流量而被騙支付的費用高達 180億美元。互聯網的快速普及,帶動了互聯網廣告產業的快速發展。
區塊鏈技術分布式存儲、不可篡改、共識機制等的技術特性決定了它可以很好地解決醫藥供應鏈大數據資源分散、數據隱私保密性要求高、互聯網在線售藥
我們持續對加密貨幣網絡的狀況做了縱向研究,包括比特幣和以太坊。 我們剛剛公布了我們在2015年至2017年的研究成果,該同行評議的論文在1
前言:中國文化博大精深,幾千年歷史長河中,文化底蘊在全世界影響甚廣,藝術品更是數不勝數。戰國時期百家爭鳴,文化思想空前昌盛,一度風靡世界;
近日,基於區塊鏈的去中心化旅行服務預定平台Tripio在白皮書中宣布,已經獲得 OKBlockchain Capital、BlockVC、
要提高潛在的投資報酬率,最大膽的方法是靠波段操作,典型的波段操作者在市場上進進出出,希望在市場上漲時,把全部資金投資下去,價格下跌時,把資金
隨著國際間的貿易接觸日趨頻繁以及全球金融市場的整合,外匯市場實際上已成為全球最大的金融交易市場
外_匯_邦 WaiHuiBang.com 在期貨市場、外匯保證金風險市場,最終的嬴家要養成良好的習慣才能獲得勝利。這是我幾年前,通過反復交易
最佳答案: 這個聚劃算百億補貼的專享劵只有特定商品才有,而且只有在每天的0點、10點、16點、20點
最佳答案: 信用卡逾期後結清了,銀行會在T+1日上報到央行征信系統去,收到信息後,征信系統會及時更新