程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> VC >> vc教程 >> visual c++對大型數據文件的讀取

visual c++對大型數據文件的讀取

編輯:vc教程

  筆者前不久曾遇到一個問題,解決之後的經驗願與大家分享。問題是這樣的,有一批數據文件,數據格式如下:

日期,開盤,最高,最低,收盤,成交量,成交金額

1996年5月13日,636.96,636.96,636.96,636.96,0,0,

1996年5月14日,641.61,641.61,641.61,641.61,0,0,

1996年5月15日,637.83,637.83,637.83,637.83,0,0,

.............

  要求將數據填寫到四張表中,以便作相應的分析。筆者開始用CFile和CStdioFile類的方法讀取件。Cfile類提供了基於二進制流的文件操作,功能類似於C語言中的fread()和fwrite()函數。CStdioFile提供了基於字符串流的文件操作,功能類似於C語言中fgets()和fputs()函數。但是筆者發現,使用這兩個類進行文件操作時,對於一次文件讀寫的數據量的大小必須限制在65535字節以內。究其原因是在VC中訪問大於65535字節的緩沖區需要Huge型指針,而在CFile和CStdioFile類中,使用的是Far型的指針。由於Far型指針不具有跨段尋址的能力,因此限制了一次文件讀寫的長度小於65535字節。如果傳遞給CFile和CStdioFile兩個類的成員函數的數據緩沖區的大小大於65535字節的時候,VC就會產生ASSERT錯誤。

  針對文件格式特點,筆者改用CArchive類進行讀取如下:

CFile SourceFile;//數據文件

CString SourceData;//定義一臨時變量保存一條記錄

SourceFile.Open(.......);

CArchive ar(&SourceFile,CArchive::load);

while(NULL!=ar.ReadString(SourceData))//循環讀取文件,直到文件結束

{

if(SourceData=="日期,開盤,最高,最低,收盤,成交量,成交金額"||SourceData=="")

continue;//跳過文件頭部的提示信息

  //分析並填充//

}

  在進行分析時,筆者采取了逐步分析並修改的辦法,過程如下:

int nYear;

CString Year= SourceData.Left(SourceData.Find("年"));//截取年前面的字符串

nYear=atoi(Year);//類型轉換

SourceData=SourceData.Righ(SourceData.GetLength()-SourceData.Find("年")-2);//將年以及前面的字符刪除。

  重復上面分析過程,直到記錄末尾。

  通過上述方法,筆者成功地將文件讀取並分析填充。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved