MQL4文件操作函数(三)

本组函数用于处理文件。

存放工作文件的三个目录(含子目录):

  • /HISTORY/<当前经纪商> – 特别提供的FileOpenHistory函数:
  • /EXPERTS/FILES – 公用目录;
  • /TESTER/FILES – 测试专用。

禁止访问来自于其他目录的工作文件。

  • FileClose() – 关闭文件
  • FileDelete() – 删除文件
  • FileFlush() – 清除文件缓冲区并存盘
  • FileIsEnding() – 判断文件指针是否到文件尾
  • FileIsLineEnding() – 判断文件指针是否指向行尾
  • FileOpen() – 打开文件
  • FileOpenHistory() – 打开历史目录下文件
  • FileReadArray() – 文件读取到数组
  • FileReadDouble() – 从文件读取浮点型数据
  • FileReadInteger() – 从文件读取整型数据
  • FileReadNumber() – 从文本文件读取数值
  • FileReadString() – 从文件读取字符串
  • FileSeek() – 移动文件指针
  • FileSize() – 获取文件大小
  • FileTell() – 获取文件指针位置
  • FileWrite() – 写入CSV文件
  • FileWriteArray() – 数组内容写入文件
  • FileWriteDouble() – 双精度数值写入文件
  • FileWriteInteger() – 整型数值写入文件
  • FileWriteString() – 字符串写入文件

 

FileSize() – 获取文件大小

int FileSize(int handle)

本函数返回文件大小(字节数)。

如果想获取详细的错误信息,请调用 GetLastError() 函数。

参数:

handle - 用 FileOpen()函数返回的句柄。

示例:

  int handle;
  int size;
  handle=FileOpen("my_table.dat", FILE_BIN|FILE_READ);
  if(handle>0)
    {
     size=FileSize(handle);
     Print("my_table.dat 大小为 ", size, " bytes");
     FileClose(handle);
    }
Back to Top

FileTell() – 获取文件指针位置

int FileSize(int handle)

本函数返回文件指针的当前位置。

如果想获取详细的错误信息,请调用 GetLastError() 函数。

参数:

handle - 用 FileOpen()函数返回的句柄。

示例:

  int handle;
  int pos;
  handle=FileOpen("my_table.dat", FILE_BIN|FILE_READ);
  // 读取数据
  pos=FileTell(handle);
  Print("current position is ", pos);
Back to Top

FileWrite() – 写入CSV文件

int FileSize(int handle,...)

本函数用于向CSV文件写入数据,并自动插入数据分隔符。在写入文件后,每行的尾端将会添加"/r/n"回车换行符。数值将会转变成文本(参看 Print() 函数)。

本函数返回写入的字符个数,如果写入出错,返回一个负数。

参数:

handle - 用 FileOpen()函数返回的句柄。
...    - 用户写入的数据用逗号分隔,最多支持63个参数。int型和double型数据自动转换
          成字符串,但不自动转换颜色型、日期时间型、布尔型数据,他们被当作数值写入 
          文件。数组不能作为参数传递。 

示例:

  int handle;
  datetime orderOpen=OrderOpenTime();
  handle=FileOpen("filename", FILE_CSV|FILE_WRITE, ';');
  if(handle>0)
    {
     FileWrite(handle, Close[0], Open[0], High[0], Low[0], TimeToStr(orderOpen));
     FileClose(handle);
    }
Back to Top

FileWriteArray() – 数组内容写入文件

int FileWriteArray(int handle,object array[], int start, int count)

本函数将数组内容写入一个二进制文件。整型、布尔型、日期时间型和颜色型数组元素作为4字节整数写入文件;双精度型数组元素作为8字节浮点数写入文件;字符串型数组直接写入文件;并在每串末尾自动添加 "/r/n” 回车换行符。

本函数返回写入内容的个数,如果写入出错,返回负值。

参数:

handle - 用 FileOpen()函数返回的句柄。
array[] - 要写入文件的数组。 
start - 写入数据的开始位置(写入文件的第一个元素的数组下标)。 
count - 要写入文件数组元素的个数。 

示例:

  int handle;
  double BarOpenValues[10];
  //  复制前十个柱体(K线)到数组
  for(int i=0;i<10; i++)
    BarOpenValues[i]=Open[i];
  // 将数组数据写入到文件
  handle=FileOpen("mydata.dat", FILE_BIN|FILE_WRITE);
  if(handle>0)
    {
     FileWriteArray(handle, BarOpenValues, 3, 7); // 写入最后7个元素
     FileClose(handle);
    }
Back to Top

FileWriteDouble() – 双精度数值写入文件

int FileWriteDouble(int handle, double value, void size)

本函数将双精度数写入二进制文件。如果格式被指定为FLOAT_VALUE,值将作为4字节浮点数写入(浮点型),否则,它以8字节浮点数格式写入(双精度型)。

返回实际写入的字节数,如果写入出错,返回负值。

参数:

handle - 用 FileOpen()函数返回的句柄。
value - 要写入文件的数值。 
size - 选择格式。可以是以下的任意值: 
       DOUBLE_VALUE (8 字节,默认值)
       FLOAT_VALUE (4 字节)

示例:

  int handle;
  double var1=0.345;
  handle=FileOpen("mydata.dat", FILE_BIN|FILE_WRITE);
  if(handle<1)
    {
     Print("不能打开文件错误-",GetLastError());
     return(0);
    }
  FileWriteDouble(h1, var1, DOUBLE_VALUE);
  //...
  FileClose(handle);
Back to Top

FileWriteInteger() – 整型数值写入文件

int FileWriteInteger(int handle, int value, void size)

本函数将整型数值写入二进制文件。如果格式被指定为SHORT_VALUE,值将作为2字节整型(短整型),如果格式被指定为CHAR_VALUE,值将作为1字节整型(字符型),否则,它以4字节整型格式(长整型)写入。

返回实际写入的字节数,如果写入出错,返回负值。

参数:

handle - 用 FileOpen()函数返回的句柄。
value - 要写入文件的数值。 
size - 选择格式。可以是以下的任意值: 
       CHAR_VALUE (1 字节)
       SHORT_VALU (2 字节)
       LONG_VALUE (4 字节,默认值)

示例:

  int handle;
  int value=10;
  handle=FileOpen("filename.dat", FILE_BIN|FILE_WRITE);
  if(handle<1)
    {
     Print("不能打开文件错误-",GetLastError());
     return(0);
    }
  FileWriteInteger(handle, value, SHORT_VALUE);
  //...
  FileClose(handle);
Back to Top

FileWriteString() – 字符串写入文件

int FileWriteString(int handle, string value, int length)

本函数将字符串写入二进制文件的当前位置。

本函数返回实际写入的字节数,如果写入出错,返回负值。

参数:

handle - 用 FileOpen()函数返回的句柄。
value - 要写入文件的字符串。 
length - 写入的字符串长度。如果字符串长度超出给定的值,多余部分将被截掉。
         如果它较短,不足部分将用二进制0填充到给定的长度。

示例:

  int handle;
  string str="some string";
  handle=FileOpen("filename.bin", FILE_BIN|FILE_WRITE);
    if(handle<1)
    {
     Print("不能打开文件错误-",GetLastError());
     return(0);
    }
  FileWriteString(h1, str, 8);
  FileClose(handle);
Back to Top

 

 


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

 

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

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

風險提示

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

邁投公眾號

聯繫我們

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

MyFxtops 邁投