[MT4-EA]智能交易的特性
[backcolor=rgb(251, 251, 252)]在MetaTrader 4交易系统中创建并测试智能交易存在以下列举特性。[/backcolor]
[backcolor=rgb(251, 251, 252)][list] [*]在开仓之前必须验证账户内是否存在自由保证金。如果账户内的自由保证金不足,开仓交易将失败。您可以测试检验"FreeMargin"值不能够少于1000,因为测试期间一个标准手的的价格为 1000。if
(
AccountFreeMargin
()
<
1000
)
return
(
0
)
;
// 没有保证金 - 退出
[*]您可以通过使用预设定数组Time, Open, Low, High, Close, Volume 获取历史数据。因为历史数据的原因,指数的增长是逐渐递减-指数的最后值为0。指数 1 表示倒数一个时间周期,指数2表示倒数两个时间周期,指数3 倒数三个时间周期以此类推。// 如果前一个蜡烛柱的Close少于
// 前者的Close
if
(
Close
[
1
<
Close
[
2
])
return
(
0
)
;
[*]使用其他的时间间隔甚至是其他货币对可以获得当前历史的数据。得到这些数据首先需要确定一维数组,并且在函数"ArrayCopySeries"的帮助下完成复制工作。对于函数的调用您可以发送较少数量的参量,并且不指明默认参量。double eur_close_m1;int number_copied = ArrayCopySeries(eur_close_m1, MODE_CLOSE, "EURUSD", PERIOD_M1);
[/list][/backcolor]
[list] [*]智能交易的编写与其他程序创建一样需要一些附加的调试信息。 MQL4
语言提供了几种获取信息的方法。 [list] [*]函数 "Alert" 会出现一个对话窗口显示用户指定数据。Alert
(
"
FreeMargin grows to
"
,
AccountFreeMargin
()
,
"
!
"
)
;
[*]函数 "Comment"将会在图表窗口的左上角显示用户指定的数据。符号"\n" 使用于字行的转接。Comment
(
"
FreeMargin is
"
,
AccountFreeMargin
()
,
"
.
"
)
;
[*]函数"Print"在系统日志中打印用户指定的数据。Print
(
"
FreeMargin is
"
,
AccountFreeMargin
()
,
"
.
"
)
;
[/list] [*]程序中错误的获取,函数"GetLastError"的功能非常有用。例如,交易订单经常返回替克数。如果这个替克数字等于 0 (在执行业务过程中出现了错误),获取这个错误的详细信息必须调用函数"GetLastError":int iTickNum = 0;int iLastError = 0;...iTickNum = OrderSend(Symbol(), OP_BUY, g_Lots, Ask, 3, 0, Ask + g_TakeProfit * g_Points);if(iTickNum <= 0) { iLastError = GetLastError(); if(iLastError != ERR_NO_ERROR) Alert("Some Message");
}
调用"GetLastError"函数可以显示错误代码,并且重新设置改值。 因此连续调用这个函数返回的值将是0。 [*]怎样确定开始柱? (必须找到先前柱结束的位置)存在以下几种方法。 第一种方法以检测柱的数量为基础:static
int
prevbars
=
0
;...
if
(
prevbars
==
Bars
)
return
(
0
)
;
prevbars
=
Bars
;...
这种方法在历史加载的情况下不能运行。在“先前”柱没有完成之间,柱的数量发生改变。这种情况下您可以检查这些值之间的差距等于1。 接下来这种方法是以 "Volume" 值为基础取决先前每个柱生成的替克的数量。第一个替克意味着形成柱的"Volume"值等于 1:if
(
Volume
[
0
>
1
)
return
(
0
)
;...
这种方法在大量价格替克输入时可能会运行失败。问题在于价格替克的输入时实行单独的作业。如果当下一个替克进入时这个作业处于繁忙状态,那么进入的这个替克则不能进入以避免超载的出现!这种情况下可以使用先前保存的 "Volume"执行检测。 第三种方法是以柱的打开时间为基础:static
datetime
prevtime
=
0
;...
if
(
prevtime
==
Time
[
0
])
return
(
0
)
;
prevtime
=
Time
[
0
;...
这种方法是最保险的方法。它能够在任意条件下运行。 [*]"CSV"类型文件运行的范例:int
h1
;
h1
=
FileOpen
(
"
my_data.csv
"
,
MODE_CSV
|
MODE_WRITE
,
"
;
"
)
;
if
(
h1
<
0
)
{
Print
(
"
Unable to open file my_data.csv
"
)
;
return
(
false
)
;
}
FileWrite
(
h1
,
High
[
1
,
Low
[
1
,
Close
[
1
,
Volume
[
1
])
;
FileClose
(
h1
)
;
对于代码的一些描述。首先打开"CSV"格式文件。在打开文件时生成错误将会对出程序。在文件成功打开后,清除文件内容并复制数据到文件内,随后关闭文件。如果您需要保存文件原有的内容,可以使用 MODE_READ模式打开:int
h1
;
h1
=
FileOpen
(
"
my_data.csv
"
,
MODE_CSV
|
MODE_WRITE
|
MODE_READ
,
"
;
"
)
;
if
(
h1
<
0
)
{
Print
(
"
Unable to open file my_data.csv
"
)
;
return
(
false
)
;
}
FileSeek
(
h1
,
0
,
SEEK_END
)
;
FileWrite
(
h1
,
High
[
1
,
Low
[
1
,
Close
[
1
,
Volume
[
1
])
;
FileClose
(
h1
)
;
这个范例中数据被添加到文件的尾页。在文件打开后,我们可以使用函数 "FileSeek"。 [/list]
[backcolor=rgb(251, 251, 252)][list] [*]在开仓之前必须验证账户内是否存在自由保证金。如果账户内的自由保证金不足,开仓交易将失败。您可以测试检验"FreeMargin"值不能够少于1000,因为测试期间一个标准手的的价格为 1000。if
(
AccountFreeMargin
()
<
1000
)
return
(
0
)
;
// 没有保证金 - 退出
[*]您可以通过使用预设定数组Time, Open, Low, High, Close, Volume 获取历史数据。因为历史数据的原因,指数的增长是逐渐递减-指数的最后值为0。指数 1 表示倒数一个时间周期,指数2表示倒数两个时间周期,指数3 倒数三个时间周期以此类推。// 如果前一个蜡烛柱的Close少于
// 前者的Close
if
(
Close
[
1
<
Close
[
2
])
return
(
0
)
;
[*]使用其他的时间间隔甚至是其他货币对可以获得当前历史的数据。得到这些数据首先需要确定一维数组,并且在函数"ArrayCopySeries"的帮助下完成复制工作。对于函数的调用您可以发送较少数量的参量,并且不指明默认参量。double eur_close_m1;int number_copied = ArrayCopySeries(eur_close_m1, MODE_CLOSE, "EURUSD", PERIOD_M1);
[/list][/backcolor]
[list] [*]智能交易的编写与其他程序创建一样需要一些附加的调试信息。 MQL4
语言提供了几种获取信息的方法。 [list] [*]函数 "Alert" 会出现一个对话窗口显示用户指定数据。Alert
(
"
FreeMargin grows to
"
,
AccountFreeMargin
()
,
"
!
"
)
;
[*]函数 "Comment"将会在图表窗口的左上角显示用户指定的数据。符号"\n" 使用于字行的转接。Comment
(
"
FreeMargin is
"
,
AccountFreeMargin
()
,
"
.
"
)
;
[*]函数"Print"在系统日志中打印用户指定的数据。Print
(
"
FreeMargin is
"
,
AccountFreeMargin
()
,
"
.
"
)
;
[/list] [*]程序中错误的获取,函数"GetLastError"的功能非常有用。例如,交易订单经常返回替克数。如果这个替克数字等于 0 (在执行业务过程中出现了错误),获取这个错误的详细信息必须调用函数"GetLastError":int iTickNum = 0;int iLastError = 0;...iTickNum = OrderSend(Symbol(), OP_BUY, g_Lots, Ask, 3, 0, Ask + g_TakeProfit * g_Points);if(iTickNum <= 0) { iLastError = GetLastError(); if(iLastError != ERR_NO_ERROR) Alert("Some Message");
}
调用"GetLastError"函数可以显示错误代码,并且重新设置改值。 因此连续调用这个函数返回的值将是0。 [*]怎样确定开始柱? (必须找到先前柱结束的位置)存在以下几种方法。 第一种方法以检测柱的数量为基础:static
int
prevbars
=
0
;...
if
(
prevbars
==
Bars
)
return
(
0
)
;
prevbars
=
Bars
;...
这种方法在历史加载的情况下不能运行。在“先前”柱没有完成之间,柱的数量发生改变。这种情况下您可以检查这些值之间的差距等于1。 接下来这种方法是以 "Volume" 值为基础取决先前每个柱生成的替克的数量。第一个替克意味着形成柱的"Volume"值等于 1:if
(
Volume
[
0
>
1
)
return
(
0
)
;...
这种方法在大量价格替克输入时可能会运行失败。问题在于价格替克的输入时实行单独的作业。如果当下一个替克进入时这个作业处于繁忙状态,那么进入的这个替克则不能进入以避免超载的出现!这种情况下可以使用先前保存的 "Volume"执行检测。 第三种方法是以柱的打开时间为基础:static
datetime
prevtime
=
0
;...
if
(
prevtime
==
Time
[
0
])
return
(
0
)
;
prevtime
=
Time
[
0
;...
这种方法是最保险的方法。它能够在任意条件下运行。 [*]"CSV"类型文件运行的范例:int
h1
;
h1
=
FileOpen
(
"
my_data.csv
"
,
MODE_CSV
|
MODE_WRITE
,
"
;
"
)
;
if
(
h1
<
0
)
{
(
"
Unable to open file my_data.csv
"
)
;
return
(
false
)
;
}
FileWrite
(
h1
,
High
[
1
,
Low
[
1
,
Close
[
1
,
Volume
[
1
])
;
FileClose
(
h1
)
;
对于代码的一些描述。首先打开"CSV"格式文件。在打开文件时生成错误将会对出程序。在文件成功打开后,清除文件内容并复制数据到文件内,随后关闭文件。如果您需要保存文件原有的内容,可以使用 MODE_READ模式打开:int
h1
;
h1
=
FileOpen
(
"
my_data.csv
"
,
MODE_CSV
|
MODE_WRITE
|
MODE_READ
,
"
;
"
)
;
if
(
h1
<
0
)
{
(
"
Unable to open file my_data.csv
"
)
;
return
(
false
)
;
}
FileSeek
(
h1
,
0
,
SEEK_END
)
;
FileWrite
(
h1
,
High
[
1
,
Low
[
1
,
Close
[
1
,
Volume
[
1
])
;
FileClose
(
h1
)
;
这个范例中数据被添加到文件的尾页。在文件打开后,我们可以使用函数 "FileSeek"。 [/list]
遇到矛盾 先站在对方的立场上想想问题,先试着去理解别人
● 如何使用WinMTR查询平台连接流畅度
发表于:2013-11-12 23:40只看该作者
2楼
看看
韬客社区www.talkfx.co
发表于:2015-02-10 12:06只看该作者
3楼
到底好用不好用
韬客社区www.talkfx.co