青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 29,comments - 10,trackbacks - 0
   首先,需要創建兩個類:CCsvFile(派生自CStdioFile,用于從屋里文件中讀取數據)和CCsvRecord(派生自CObject,適合作為CCsvFile類的Object映射成員,包含指定行的數據。
1)CCsvRecord類的創建
   由于每個CSV記錄都包含很多列,所以增加一個名為m_arrCloumns的CStringArray類型的成員變量(該變量包含記錄的真正數據):
protected:
    CStringArray m_arrColumns;
   接下來,編寫構造函數,獲得包含以逗號分隔記錄的字符串數值。使用C語言的strtok函數來遍歷字符串尋找逗號,每當找到一個逗號的時候,變量的token就包含逗號前面的值。然后,將這個值添加到m_arrColumns數組中。
char DELIMITERS[] = ",";

CCsvRecord::CCsvRecord(LPTSTR lpszRecord)
{
    
char *token;
    token 
= strtok(lpszRecord, DELIMITERS);

    
while(NULL != token)
    {
        m_arrColumns.Add(token);
        token 
= strtok(NULL, DELIMITERS);    
    }
}
   最后,添加返回m_arrCloumns數據的大小和檢索與一列相關的數據
UINT CCsvRecord::GetNbrOfColumns()
{
    
return m_arrColumns.GetSize();
}

CString CCsvRecord::GetColumn(UINT uiColumn)
{
    CString strColumn;    
    
if (((uiColumn >= 0)    && (uiColumn <= (GetNbrOfColumns() - 1))))
    {
        strColumn 
= m_arrColumns[uiColumn];
    }    
    
return strColumn;
}
2)CCsvFile類的創建
   首先,定義CCsvFile對象的集合,使用模板化的集合來保證類型的安全,并定義數組m_CsvRecordArray。EnsOfFile值是一個枚舉型的值,用來判斷是否到達文件尾。FileExists判斷文件是否存在。m_dwNumberOfRecords返回數組的大小,即表示文件中包含的記錄數。
typedef CTypedPtrArray<CObArray, CCsvRecord*> CCsvRecordArray;

class CCsvFile : public CStdioFile
{
public:
    CCsvFile(LPSTR lpszFileName);
    CCsvFile(CString
& strFileName);
    
~CCsvFile();
protected:
    
void Initialize(LPSTR lpszFileName);
public:
    
enum
    {
        EndOfFile 
= -1
    };
    
public:
    
static BOOL FileExists(LPCTSTR lpszFileName) 
    {
        
return (0 == (_access(lpszFileName, 4)));
    }
    
protected:
    DWORD LoadRecords();
    
protected:
    DWORD m_dwNumberOfRecords;
public:
    DWORD GetNumberOfRecords()
    {
        
return m_dwNumberOfRecords;
    }
protected:
    CCsvRecordArray m_CsvRecordArray;
public:
    UINT GetStartPosition();
    
void GetNextAssoc(UINT& rPosition, CCsvRecord** ppCsvRecord);
};
   利用Initialize對兩個構造函數進行初始化,讀取物理文件并得出包含的記錄數
CCsvFile::CCsvFile(LPSTR lpszFileName)
{
    Initialize(lpszFileName);
}

CCsvFile::CCsvFile(CString
& strFileName)
{
    Initialize(strFileName.GetBuffer(
0));
}

void CCsvFile::Initialize(LPSTR lpszFileName)
{
    m_dwNumberOfRecords 
= 0;
    
    ASSERT(lpszFileName 
!= NULL);
    ASSERT(AfxIsValidString(lpszFileName));
    
    
if (CCsvFile::FileExists(lpszFileName))
    {
        
if (Open(lpszFileName, CFile::modeRead))
        {
            m_dwNumberOfRecords 
= LoadRecords();
        }
    }    
}

DWORD CCsvFile::LoadRecords()
{
    m_dwNumberOfRecords 
= 0;
    
    CCsvRecord
* pCsvRecord;
    CString strRecord;
    
while (ReadString(strRecord))
    {
        pCsvRecord 
= new CCsvRecord(strRecord.GetBuffer(0));
        
        ASSERT(pCsvRecord);
        
if (pCsvRecord)
        {
            m_CsvRecordArray.Add(pCsvRecord);
        }
        strRecord.ReleaseBuffer();
    }
    
    
return m_CsvRecordArray.GetSize();
}
   增加兩個遍歷記錄數組的函數,GetStrarPosition和GetNextAssoc函數
UINT CCsvFile::GetStartPosition()
{
    UINT uiPosition;
    
    
if (0 < m_CsvRecordArray.GetSize())
    {
        uiPosition 
= 0;
    }
    
else
    {
        uiPosition 
= CCsvFile::EndOfFile;
    }
    
    
return uiPosition;
}

void CCsvFile::GetNextAssoc(UINT& uiPosition, CCsvRecord** ppCsvRecord)
{
    UINT uiNewPosition 
= CCsvFile::EndOfFile;
    
*ppCsvRecord = NULL;
    
    UINT nRecords 
= m_CsvRecordArray.GetSize();
    
if (uiPosition >= 0 && uiPosition <= (nRecords - 1))
    {
        
*ppCsvRecord = m_CsvRecordArray[uiPosition];
        
if ( (uiPosition + 1<= (nRecords - 1) )
        {
            uiNewPosition 
= uiPosition + 1;
        }
    }
    
    uiPosition 
= uiNewPosition;
}
   最后,編寫西溝函數來清楚前面分配的CCsvRecord對象:
CCsvFile::~CCsvFile()
{
    CCsvRecord
* pCsvRecord;
    
for (int i = m_CsvRecordArray.GetUpperBound(); i > -1; i--)
    {
        pCsvRecord 
= m_CsvRecordArray[i];
        m_CsvRecordArray.RemoveAt(i);
        
        ASSERT(pCsvRecord);
        
if (pCsvRecord)
        {
            delete pCsvRecord;
        }
    }
    VERIFY(
0 == m_CsvRecordArray.GetSize());
}
   3)打印和顯示CSV文件

   單擊Open事件,在實例化CCsvFile之后,只需在for循環中使用GetStratPosition和GetNextAssoc函數來檢索CCsvRecord對象。并對每條記錄調用InsertDataIntoListView函數。
void CCViewCSVDlg::OnButton1() 
{
    CFileDialog dlg(
true);
    
if (IDOK == dlg.DoModal())
    {
        
try
        {
            m_strFileName 
= dlg.GetPathName();
            UpdateData(FALSE);
            
            CCsvFile file(dlg.GetPathName());
            
            CCsvRecord
* pCsvRecord;
            
for (UINT uiRow = file.GetStartPosition();
            CCsvFile::EndOfFile 
!= uiRow;)
            {
                
// get the actual record
                file.GetNextAssoc(uiRow, &pCsvRecord);
                
if (pCsvRecord)
                {
                    InsertDataIntoListView(uiRow, 
*pCsvRecord);
                }
            }
        }
        
catch(CFileException* pe)
        {
            pe
->ReportError();
        }
    }
    SizeAllColumns();
}

void CCViewCSVDlg::InsertDataIntoListView(UINT uiRow, CCsvRecord& csvRecord)
{
    
// For each column in the passed record
    for (int iCol = 0; iCol < csvRecord.GetNbrOfColumns(); iCol++)
    {
        
// If this is the first row in the listview    
        if (uiRow == 1)
        {
            
// Create the listview columns.
            CString strColumnName;
            strColumnName.Format(
"Col %ld", iCol);
            m_lstFileContents.InsertColumn(iCol, strColumnName);
        }
        
        
if (iCol == 0)
            m_lstFileContents.InsertItem(m_lstFileContents.GetItemCount(), 
            csvRecord.GetColumn(iCol));
        
else
            m_lstFileContents.SetItemText(m_lstFileContents.GetItemCount()
-1,
            iCol,csvRecord.GetColumn(iCol));
    }
}
   最后,設置好列表框的每列的寬度
void CCViewCSVDlg::SizeAllColumns()
{
    CHeaderCtrl
* pHeader = m_lstFileContents.GetHeaderCtrl();
    ASSERT(pHeader);
    
if (pHeader)
    {
        
// Turn off redraw until the columns have all
        
// been resized
        m_lstFileContents.SetRedraw(FALSE);
        
        
for (int iCurrCol = 0
        iCurrCol 
< pHeader->GetItemCount(); 
        iCurrCol
++)
        {
            m_lstFileContents.SetColumnWidth(iCurrCol, LVSCW_AUTOSIZE);
            
            
int nCurrWidth = m_lstFileContents.GetColumnWidth(iCurrCol);
            
            m_lstFileContents.SetColumnWidth(iCurrCol,
                LVSCW_AUTOSIZE_USEHEADER);
            
            
int nColHdrWidth = m_lstFileContents.GetColumnWidth(iCurrCol);
            
            m_lstFileContents.SetColumnWidth(iCurrCol, 
                max(nCurrWidth, nColHdrWidth));
        }
        
        
// Now that sizing is finished, turn redraw back on and 
        
// invalidate so that the control is repainted
        m_lstFileContents.SetRedraw(TRUE);
        m_lstFileContents.Invalidate();
    }
}
 4)相關函數:
token = strtok(lpszRecord, DELIMITERS);

typedef CTypedPtrArray<CObArray, CCsvRecord*> CCsvRecordArray;

return (0 == (_access(lpszFileName, 4)));

ASSERT(AfxIsValidString(lpszFileName));

for (int i = m_CsvRecordArray.GetUpperBound(); i > -1; i--)
m_CsvRecordArray.RemoveAt(i);
VERIFY(0 == m_CsvRecordArray.GetSize());

pCsvRecord = new CCsvRecord(strRecord.GetBuffer(0));
strRecord.ReleaseBuffer();

m_lstFileContents.InsertColumn(iCol, strColumnName);
m_lstFileContents.InsertItem(m_lstFileContents.GetItemCount(),csvRecord.GetColumn(iCol));
m_lstFileContents.SetItemText(m_lstFileContents.GetItemCount()-1,iCol,csvRecord.GetColumn(iCol));

m_lstFileContents.SetRedraw(FALSE);
m_lstFileContents.SetColumnWidth(iCurrCol, LVSCW_AUTOSIZE);
int nCurrWidth = m_lstFileContents.GetColumnWidth(iCurrCol);
m_lstFileContents.SetRedraw(TRUE);
m_lstFileContents.Invalidate();
posted on 2009-07-29 23:06 The_Moment 閱讀(2935) 評論(2)  編輯 收藏 引用 所屬分類: VC實踐

FeedBack:
# re: CSV逗號分隔值文件(Comma Separated value)
2010-05-09 21:44 | dqf
非常不錯。
可以發給我一份源碼嗎?
我的email:dqf88@sohu.com  回復  更多評論
  
# re: CSV逗號分隔值文件(Comma Separated value)
2010-10-27 10:49 | mixed_now
非常好。
可以發給我一份源碼嗎?
我的email:mixed_now@163.com  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲国产精品久久人人爱蜜臀| 国产精品狼人久久影院观看方式| 久久精品二区三区| 亚洲一级二级| 亚洲少妇自拍| 亚洲午夜久久久久久尤物 | 久久综合色综合88| 欧美一区二区三区在线观看视频| 亚洲男人av电影| 欧美在线国产精品| 久久精品综合| 欧美成人免费小视频| 亚洲第一区在线观看| 最近看过的日韩成人| 亚洲一区二区黄色| 久久久999精品免费| 欧美激情亚洲一区| 国产精品一区二区视频| 一区二区视频免费完整版观看| 最近中文字幕日韩精品| 亚洲影院一区| 欧美丰满高潮xxxx喷水动漫| 亚洲精选一区| 欧美一区2区三区4区公司二百| 美女91精品| 国产精品久久久久久久久久尿 | 国产精品视区| 在线欧美视频| 香蕉尹人综合在线观看| 欧美国产91| 亚洲欧美日韩国产中文| 欧美黄色一区二区| 韩国精品一区二区三区| 亚洲精品一区二区三区99| 欧美亚洲免费| 亚洲精选视频免费看| 久久久久久久999精品视频| 国产精品成人播放| 亚洲精选在线| 免费成人av在线| 亚洲素人一区二区| 欧美大片一区二区三区| 在线成人激情| 亚洲女女女同性video| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲自拍偷拍色片视频| 久久久久9999亚洲精品| 国产精品久久久久影院色老大 | 西西人体一区二区| 亚洲乱码久久| 美女精品国产| 香蕉av福利精品导航| 亚洲精品美女久久久久| 久久久久久久综合狠狠综合| 国产欧美日韩综合一区在线播放| 夜夜嗨av一区二区三区网页| 欧美丰满少妇xxxbbb| 久久成人18免费网站| 国产欧美日韩另类视频免费观看| 亚洲图色在线| 亚洲人成在线观看| 欧美大片在线看免费观看| 在线免费观看视频一区| 久久婷婷色综合| 久久狠狠一本精品综合网| 国产精品五月天| 午夜日韩福利| 亚洲女人av| 国产婷婷色一区二区三区在线| 欧美一区二区视频在线| 香蕉尹人综合在线观看| 国产综合视频在线观看| 久久尤物电影视频在线观看| 久久精品天堂| 亚洲国产老妈| 亚洲精品免费看| 欧美性事免费在线观看| 欧美一区不卡| 久久狠狠亚洲综合| 黄色在线成人| 亚洲第一福利在线观看| 欧美日韩国产综合新一区| 亚洲欧美久久久| 羞羞漫画18久久大片| 激情欧美日韩| 亚洲国产合集| 国产精品区二区三区日本 | 国产精品视频不卡| 久久xxxx精品视频| 久久精品国产综合精品| 日韩视频一区二区三区| 一本色道久久综合狠狠躁篇的优点| 国产精品入口66mio| 久久久噜噜噜久久中文字幕色伊伊| 久久久久久尹人网香蕉| 中日韩视频在线观看| 欧美一级片一区| 亚洲卡通欧美制服中文| 亚洲综合视频1区| 亚洲第一区中文99精品| 亚洲一区二区三区中文字幕| 亚洲电影天堂av| 亚洲美女视频在线观看| 国产午夜久久久久| 亚洲人成在线播放网站岛国| 国产区在线观看成人精品| 亚洲国产精品久久精品怡红院| 国产精品v欧美精品v日本精品动漫 | 欧美电影打屁股sp| 欧美乱妇高清无乱码| 一本久久综合亚洲鲁鲁| 欧美一区成人| 亚洲影音一区| 欧美激情一区二区三区不卡| 久久久久免费观看| 国产精品国产三级国产aⅴ入口| 欧美成人精品不卡视频在线观看| 国产精品视频内| 亚洲精品自在久久| 亚洲激情成人在线| 先锋影音久久久| 亚洲综合日韩| 欧美午夜电影一区| 亚洲精品麻豆| 亚洲人成亚洲人成在线观看图片| 欧美在线视频日韩| 欧美一区二区三区在线视频| 国产精品久久7| 日韩天堂在线视频| 亚洲美女在线一区| 久久蜜桃精品| 久久综合九色综合欧美狠狠| 国产三级精品三级| 亚洲免费在线观看| 先锋资源久久| 国产精品视频免费观看| 亚洲免费人成在线视频观看| 亚洲欧美国产va在线影院| 欧美日韩国产精品一区| 亚洲精品小视频| 在线亚洲观看| 欧美日韩另类国产亚洲欧美一级| 亚洲国产小视频| 亚洲破处大片| 欧美激情一区二区三区四区| 亚洲激情第一页| 一区二区三区视频在线看| 欧美精品亚洲| 一区二区三区精品视频| 亚洲欧美视频| 国产综合色精品一区二区三区| 久久在线免费| 亚洲国产aⅴ天堂久久| 亚洲美女av在线播放| 欧美手机在线视频| 亚洲欧美清纯在线制服| 久久综合成人精品亚洲另类欧美| 亚洲大片精品永久免费| 欧美黄色小视频| 亚洲欧美另类在线观看| 欧美.日韩.国产.一区.二区| 99精品久久久| 国产欧美精品在线播放| 久久综合九九| 亚洲乱码国产乱码精品精天堂| 亚洲欧美综合国产精品一区| 国语自产精品视频在线看8查询8| 免费在线播放第一区高清av| av不卡免费看| 久久夜色精品国产| 国产精品99久久久久久久vr| 国产日本欧美在线观看 | 毛片基地黄久久久久久天堂| 一本色道久久| 亚洲精品久久久久久久久久久久| 一区二区三区 在线观看视频 | 亚洲成人在线| 欧美日韩一二区| 亚洲欧美日韩精品在线| 女生裸体视频一区二区三区| 亚洲欧美日韩中文视频| 亚洲国产经典视频| 国产伦精品一区二区三区免费迷| 久久综合色88| 亚洲欧美视频一区二区三区| 最近中文字幕日韩精品 | 亚洲一区精品视频| 亚洲第一中文字幕在线观看| 国产精品欧美久久| 欧美电影免费观看高清| 久久se精品一区二区| 亚洲精品一区二区三区99| 久久伊人精品天天| 欧美伊久线香蕉线新在线| 一本色道久久99精品综合| 在线免费一区三区| 尤物九九久久国产精品的分类| 国产精品无码专区在线观看| 欧美午夜寂寞影院| 欧美金8天国|