FileWriteString

이 함수는 파일 포인터의 현재 위치에서 시작하여 문자열 유형 파라미터의 값을 BIN, CSV 또는 TXT 파일에 기록합니다. CSV 또는 TXT 파일에 쓸 때: 문자열 '\n' (LF)에 이전 문자 '\r' (CR)가 없는 심볼이 있으면 '\n' 전에 누락된 '\r'가 추가됩니다.

uint  FileWriteString(
   int           file_handle,    // 파일 핸들
   const string  text_string,    // 작성할 문자열
   int           length=-1       // 심볼의 수
   );

Parameters

file_handle

[in] FileOpen()에서 반환된 파일 설명자.

text_string

[in]  문자열.

length=-1

[in] 쓸 문자 수. 이 옵션은 문자열을 BIN 파일에 쓰는 데 필요합니다. 크기가 지정되지 않은 경우, 트레일러 0이 없는 전체 문자열이 기록됩니다. 문자열 길이보다 작은 크기를 지정하면 트레일러 0이 없는 문자열의 일부가 기록됩니다. 문자열 길이보다 큰 크기를 지정하면 문자열이 적절한 수의 0으로 채워집니다. CSV 및 TXT 유형의 파일의 경우 이 매개 변수는 무시되고 문자열이 완전히 기록됩니다.

반환 값

성공하면 함수는 쓴 바이트 수를 반환합니다. 파일 포인터가 동일한 바이트 수만큼 이동됩니다.

참고

FILE_UNICODE 플래그로 열린 파일에 쓸 때(또는 FILE_ANSI 플래그 없이) 쓴 바이트 수는 기록된 문자열 문자 수보다 두 배 더 큽니다. FILE_ANSI 플래그로 열린 파일에 기록할 때, 쓴 바이트 수는 기록된 문자열 문자의 수와 일치합니다.

예:

//+------------------------------------------------------------------+
//|                                         Demo_FileWriteString.mq5 |
//|                        Copyright 2013, MetaQuotes Software Corp. |
//|                                              https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2013, MetaQuotes Software Corp."
#property link      "https://www.mql5.com"
#property version   "1.00"
//--- 스크립트를 시작할 때 입력 매개 변수의 창을 표시합니다.
#property script_show_inputs
//--- 터미널에서 데이터를 수신하기 위한 매개 변수
input string             InpSymbolName="EURUSD";           // 통화
input ENUM_TIMEFRAMES    InpSymbolPeriod=PERIOD_H1;        // 타임프레임
input int                InpMAPeriod=14;                   // MA period
input ENUM_APPLIED_PRICE InpAppliedPrice=PRICE_CLOSE;      // 가격 유형
input datetime           InpDateStart=D'2013.01.01 00:00'; // 데이터 복사 시작 날짜
//--- 파일에 데이터를 쓰기 위한 매개 변수
input string             InpFileName="RSI.csv";   // 파일명
input string             InpDirectoryName="Data"// 디렉토리명
//+------------------------------------------------------------------+
//| 스크립트 프로그램 시작 함수                                    |
//+------------------------------------------------------------------+
void OnStart()
  {
   datetime date_finish; // 데이터 복사 종료일
   double   rsi_buff[];  // 지표 값 배열
   datetime date_buff[]; // 지표 날짜 배열
   int      rsi_size=0;  // 지표 배열 사이즈
//--- 종료 시간은 현재 시간입니다
   date_finish=TimeCurrent();
//--- RSI 지표 핸들 수령
   ResetLastError();
   int rsi_handle=iRSI(InpSymbolName,InpSymbolPeriod,InpMAPeriod,InpAppliedPrice);
   if(rsi_handle==INVALID_HANDLE)
     {
      //--- 지표 핸들을 수신하지 못했습니다
      PrintFormat("지표 핸들 수신 시 오류 발생. Error code = %d",GetLastError());
      return;
     }
//--- 지표가 모든 값을 계산할 때까지 루프에 있음
   while(BarsCalculated(rsi_handle)==-1)
      Sleep(10); // 지표가 모든 값을 계산할 수 있도록 잠시 정지
//--- 일정 기간 동안 지표 값을 복제
   ResetLastError();
   if(CopyBuffer(rsi_handle,0,InpDateStart,date_finish,rsi_buff)==-1)
     {
      PrintFormat("지표값 복제 실패. Error code = %d",GetLastError());
      return;
     }
//--- 지표값에 적절한 시간을 복제
   ResetLastError();
   if(CopyTime(InpSymbolName,InpSymbolPeriod,InpDateStart,date_finish,date_buff)==-1)
     {
      PrintFormat("시간 값 복제 실패. Error code = %d",GetLastError());
      return;
     }
//--- 지표의 메모리를 비움
   IndicatorRelease(rsi_handle);
//--- 버퍼 사이즈 수령
   rsi_size=ArraySize(rsi_buff);
//--- 지표 값을 쓰기 위해 파일을 엽니다(파일이 없을 경우 자동으로 생성됨)
   ResetLastError();
   int file_handle=FileOpen(InpDirectoryName+"//"+InpFileName,FILE_READ|FILE_WRITE|FILE_CSV|FILE_ANSI);
   if(file_handle!=INVALID_HANDLE)
     {
      PrintFormat("%s 파일을 쓸 수 있습니다",InpFileName);
      PrintFormat("파일 경로: %s\\Files\\",TerminalInfoString(TERMINAL_DATA_PATH));
      //--- 변수를 추가로 준비
      string str="";
      bool   is_formed=false;
      //--- 과매수 및 과매도 영역의 형성 날짜 작성
      for(int i=0;i<rsi_size;i++)
        {
         //--- 지표 값 확인
         if(rsi_buff[i]>=70 || rsi_buff[i]<=30)
           {
            //--- 값이 이 영역에서 첫 번째일 경우
            if(!is_formed)
              {
               //--- 값과 날짜를 더함
               str=(string)rsi_buff[i]+"\t"+(string)date_buff[i];
               is_formed=true;
              }
            else
               str+="\t"+(string)rsi_buff[i]+"\t"+(string)date_buff[i];
            //--- 다음 루프 반복으로 이동
            continue;
           }
         //--- 플래그 확인
         if(is_formed)
           {
            //--- 문자열이 형성되면, 파일에 작성
            FileWriteString(file_handle,str+"\r\n");
            is_formed=false;
           }
        }
      //--- 파일 닫기
      FileClose(file_handle);
      PrintFormat("데이터가 작성됐습니다, %s 파일이 닫힙니다",InpFileName);
     }
   else
      PrintFormat("%s 파일 열기 실패, 에러 코드 = %d",InpFileName,GetLastError());
  }

더 보기

String Type, StringFormat