EATC

 找回密码
 立即注册
查看: 1158|回复: 1

MQL4价格数据相关函数

[复制链接]

196

主题

1168

帖子

8003

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
8003
发表于 2022-9-8 11:32:35 | 显示全部楼层 |阅读模式

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

如果请求数据(货币对名称/时段不同于当前图表)来自其他图表,这种情况可能是相应的图表没有在客户端内打开,并且需要从服务器端下载数据。这种情况下,错误信息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)); 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);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));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));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)];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));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)];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));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));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),", ",     
回复

使用道具 举报

2718

主题

5151

帖子

2万

积分

交易元老

Rank: 8Rank: 8

积分
21554
发表于 2024-3-20 11:10:27 | 显示全部楼层
Thankyou
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

收藏本站|法律声明|Archiver|小黑屋|support@ea198.com|EATC ( 桂ICP备2022005787号 )

风险提示与免责声明:擅自从事外汇保证金交易的双方不受法律保护!社区内展示内容,均为网友自发分享,不构成投资建议,社区无法全面监控由第三方上传至社区的资源,因此不保证资源的合法性、安全性、完整性、真实性或品质等。您下载时,同意自行判断并承担所有风险。社区内的资源,仅限用于学习和研究目的,不得将用于商业或者非法用途,否则,一切后果请用户自负。社区信息来自网络,版权争议与社区无关,您下载后须在24个小时之内进行删除。如果您喜欢该内容,请支持正版。如有侵权请邮件与我们联系处理。