MQL4价格数据相关函数

用于获取货币对/时段内价格数据的一组函数。

如果请求数据(货币对名称/时段不同于当前图表)来自其他图表,这种情况可能是相应的图表没有在客户端内打开,并且需要从服务器端下载数据。这种情况下,错误信息ERR_HISTORY_WILL_UPDATED(4066-请求的历史数据正在更新中)将被放置到last_error变量中,并且不得不重新请求更新(参看ArrayCopySeries()范例)。

在测试中,同货币对价格数据或不同时段的价格数据被精确地模拟(除成交量外)。其他时段的成交量不模拟,其它货币对的价格数据同样也不模拟。无论何种情况,一个时段内柱子总数会被精确地模拟。

  • iBars() – 获取柱体数
  • iBarShift() – 搜索指定柱体
  • iClose() – 获取柱体收盘价
  • iHigh() – 获取柱体最高价
  • iHighest() – 柱体最高值偏移量
  • iLow() – 获取柱体最低价
  • iLowest() – 柱体最低值偏移量
  • iOpen() – 获取柱体开盘价
  • iTime() – 获取柱体开盘时间
  • iVolume() – 获取柱体成交量

 

iBars() – 获取柱体数

int iBars(string symbol, int timeframe)

返回指定的图表中柱体(K线)的数量。

对于当前图表,柱子数量的信息保存在预定义的变量Bars中。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。

示例:

Print("'EURUSD'在PERIOD_H1时段的柱数:",iBars("EUROUSD",PERIOD_H1)); 
Back to Top

iBarShift() – 搜索指定柱体

int iBarShift(string symbol, int timeframe, datetime time, void exact)

根据开盘时间搜索柱体(K线)。本函数返回带指定开盘时间的柱体。如果带指定开盘时间的柱体丢失,函数将返回-1或最近的柱体,这取决护exact参数设置。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
time - 柱体(K线)的开盘时间。
exact - 未发现柱子的返回模式。false-返回最近的柱子,true-返回-1。

示例:

datetime some_time=D'2004.03.21 12:00';
  int      shift=iBarShift("EUROUSD",PERIOD_M1,some_time);
  Print("带有打开时间的柱体 ",TimeToStr(some_time)," 是 ",shift);
Back to Top

iClose() – 获取柱体收盘价

double iClose(string symbol, int timeframe, int shift)

返回带有时段和偏移量的指定货币对柱体(K线)的收盘价。如果本地历史表为空(历史数据未加载),函数返回0。

对于当前图表,收盘价的信息保存在 预定义数组Close[] 中。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
shift     - 从指标缓冲区中获取值的索引(相对当前柱子向前移动一定数量周期的偏移量)。

示例:

Print("对于 USDCHF H1当前柱: ",iTime("USDCHF",PERIOD_H1,i),", ",  iOpen("USDCHF",PERIOD_H1,i),", ",
                                      iHigh("USDCHF",PERIOD_H1,i),", ",  iLow("USDCHF",PERIOD_H1,i),", ",
                                      iClose("USDCHF",PERIOD_H1,i),", ", iVolume("USDCHF",PERIOD_H1,i));
Back to Top

iHigh() – 获取柱体最高价

double iHigh(string symbol, int timeframe, int shift)

返回带有时段和偏移量的指定货币对柱体(K线)的最高价。如果本地历史表为空(历史数据未加载),函数返回0。

对于当前图表,最盘价的信息保存在 预定义数组High[] 中。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
shift     - 从指标缓冲区中获取值的索引(相对当前柱子向前移动一定数量周期的偏移量)。

示例:

Print("对于 USDCHF H1当前柱: ",iTime("USDCHF",PERIOD_H1,i),", ",  iOpen("USDCHF",PERIOD_H1,i),", ",
                                      iHigh("USDCHF",PERIOD_H1,i),", ",  iLow("USDCHF",PERIOD_H1,i),", ",
                                      iClose("USDCHF",PERIOD_H1,i),", ", iVolume("USDCHF",PERIOD_H1,i));
Back to Top

iHighest() – 柱体最高值偏移量

int iHighest(string symbol, int timeframe, int type, void count, void start)

根据类型返回在一个指定时间周期内最大值的偏移量。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
type      - 序列数组的识别符。它可以是 序列数据识别符枚举 的任意值。
count     - 要计算出的周期数(沿着开头柱子到后而柱子的方向)。
start     - 开始柱子,相对于当前柱子,开始采集数据的柱子。

示例:

double val;
  // 在20个连续柱子范围内计算最大值
  // 在当前图表上从第4个至第23个的索引
  val=High[iHighest(NULL,0,MODE_HIGH,20,4)];
Back to Top

iLow() – 获取柱体最低价

double iLow(string symbol, int timeframe, int shift)

返回带有时段和偏移量的指定货币对柱体(K线)的最低价。如果本地历史表为空(历史数据未加载),函数返回0。

对于当前图表,最盘价的信息保存在 预定义数组Low[] 中。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
shift     - 从指标缓冲区中获取值的索引(相对当前柱子向前移动一定数量周期的偏移量)。

示例:

Print("对于 USDCHF H1当前柱: ",iTime("USDCHF",PERIOD_H1,i),", ",  iOpen("USDCHF",PERIOD_H1,i),", ",
                                      iHigh("USDCHF",PERIOD_H1,i),", ",  iLow("USDCHF",PERIOD_H1,i),", ",
                                      iClose("USDCHF",PERIOD_H1,i),", ", iVolume("USDCHF",PERIOD_H1,i));
Back to Top

iLowest() – 柱体最低值偏移量

int iLowest(string symbol, int timeframe, int type, void count, void start)

根据类型返回在一个指定时间周期内最低值的偏移量。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
type      - 序列数组的识别符。它可以是 序列数据识别符枚举 的任意值。
count     - 要计算出的周期数(沿着开头柱子到后而柱子的方向)。
start     - 开始柱子,相对于当前柱子,开始采集数据的柱子。

示例:

double val;
  // 在20个连续柱子范围内计算最小值
  // 在当前图表上从第4个至第23个的索引
  val=Low[iLowest(NULL,0,MODE_LOW,20,4)];
Back to Top

iOpen() – 获取柱体开盘价

double iOpen(string symbol, int timeframe, int shift)

返回带有时段和偏移量的指定货币对柱体(K线)的开盘价。如果本地历史表为空(历史数据未加载),函数返回0。

对于当前图表,最盘价的信息保存在 预定义数组Open[] 中。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
shift     - 从指标缓冲区中获取值的索引(相对当前柱子向前移动一定数量周期的偏移量)。

示例:

Print("对于 USDCHF H1当前柱: ",iTime("USDCHF",PERIOD_H1,i),", ",  iOpen("USDCHF",PERIOD_H1,i),", ",
                                      iHigh("USDCHF",PERIOD_H1,i),", ",  iLow("USDCHF",PERIOD_H1,i),", ",
                                      iClose("USDCHF",PERIOD_H1,i),", ", iVolume("USDCHF",PERIOD_H1,i));
Back to Top

iTime() – 获取柱体开盘时间

datetime iTime(string symbol, int timeframe, int shift)

返回带有时段和偏移量的指定货币对柱体(K线)的开盘时间。如果本地历史表为空(历史数据未加载),函数返回0。

对于当前图表,最盘价的信息保存在 预定义数组Time[] 中。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
shift     - 从指标缓冲区中获取值的索引(相对当前柱子向前移动一定数量周期的偏移量)。

示例:

Print("对于 USDCHF H1当前柱: ",iTime("USDCHF",PERIOD_H1,i),", ",  iOpen("USDCHF",PERIOD_H1,i),", ",
                                      iHigh("USDCHF",PERIOD_H1,i),", ",  iLow("USDCHF",PERIOD_H1,i),", ",
                                      iClose("USDCHF",PERIOD_H1,i),", ", iVolume("USDCHF",PERIOD_H1,i));
Back to Top

iVolume() – 获取柱体成交量

datetime iVolume(string symbol, int timeframe, int shift)

返回带有时段和偏移量的指定货币对柱体(K线)的成交量。如果本地历史表为空(历史数据未加载),函数返回0。

对于当前图表,最盘价的信息保存在 预定义数组Volume[] 中。

:该成交量并非真正意义上的成交量,这是一个估计值,其值为该K线下tick价格变动的数量,其背后的意义为如果tick价格变动很快,表示成交量越大;tick价格变动越慢,表示成交量越小。

参数:

symbol    - 要计算指标数据的货币对名称。 NULL表示当前货币对。
timeframe - 时间周期。 可以 时间周期列举 任意值。 0表示当前图表的时间周期。
shift     - 从指标缓冲区中获取值的索引(相对当前柱子向前移动一定数量周期的偏移量)。

示例:

Print("对于 USDCHF H1当前柱: ",iTime("USDCHF",PERIOD_H1,i),", ",  iOpen("USDCHF",PERIOD_H1,i),", ",
                                      iHigh("USDCHF",PERIOD_H1,i),", ",  iLow("USDCHF",PERIOD_H1,i),", ",
                                      iClose("USDCHF",PERIOD_H1,i),", ", iVolume("USDCHF",PERIOD_H1,i));
Back to Top

 

 


MyFxtop迈投-靠谱的外汇跟单社区,免费跟随高手做交易!

 

免责声明:本文系转载自网络,如有侵犯,请联系我们立即删除,另:本文仅代表作者个人观点,与迈投财经无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。

著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。

風險提示

MyFxtops邁投所列信息僅供參考,不構成投資建議,也不代表任何形式的推薦或者誘導行為。MyFxtops邁投非外匯經紀商,不接觸妳的任何資金。 MYFXTOPS不保證客戶盈利,不承擔任何責任。從事外彙和差價合約等金融產品的槓桿交易具有高風險,損失有可能超過本金,請量力而行,入市前需充分了解潛在的風險。過去的交易成績並不代表以後的交易成績。依據各地區法律法規,MyFxtops邁投不向中國大陸、美國、加拿大、朝鮮居民提供服務。

邁投公眾號

聯繫我們

客服QQ:981617007
Email: service@myfxtop.com

MyFxtops 邁投