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

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>
            久久综合伊人77777蜜臀| 久久一区欧美| 国产精品久久久久久久久久免费看 | 亚洲视频一区二区| 一区二区三区视频在线| 国产精品永久免费观看| 久久精彩视频| 久久综合五月天婷婷伊人| 亚洲精品乱码久久久久久黑人| 亚洲高清中文字幕| 欧美日韩aaaaa| 欧美一区日本一区韩国一区| 久久久国产精品一区二区中文| 亚洲国产欧洲综合997久久| 99re66热这里只有精品3直播| 国产精品亚洲欧美| 牛人盗摄一区二区三区视频| 欧美高清在线精品一区| 亚洲欧美日韩精品| 免费亚洲一区二区| 亚洲欧美制服中文字幕| 久久综合一区二区| 小嫩嫩精品导航| 久久欧美肥婆一二区| 亚洲少妇中出一区| 久久天天狠狠| 亚洲欧美视频在线观看| 久久亚洲春色中文字幕| 亚洲一区二区三区免费视频| 久久精品国产综合精品| 日韩亚洲在线观看| 欧美在线黄色| 亚洲一区二区在线视频| 久久久激情视频| 亚洲尤物视频网| 免费一级欧美片在线观看| 欧美一区二区三区的| 欧美日韩免费区域视频在线观看| 久久久久久久久久久久久女国产乱| 欧美激情精品久久久久久黑人| 欧美一区二区视频在线| 欧美日韩三级| 欧美激情精品久久久久久黑人| 国产精品一区二区你懂的| 亚洲国产激情| 狠狠色狠狠色综合日日tαg | 小黄鸭视频精品导航| 欧美久久电影| 亚洲高清色综合| 亚洲大片在线观看| 久久国产精品亚洲va麻豆| 午夜性色一区二区三区免费视频| 欧美电影在线观看| 欧美福利小视频| 激情欧美日韩一区| 久久高清一区| 久久久精品2019中文字幕神马| 国产精品福利在线观看| 亚洲黄色在线观看| 亚洲九九爱视频| 欧美另类视频| 亚洲欧洲在线视频| 99re6热在线精品视频播放速度| 久久久综合精品| 免费观看一级特黄欧美大片| 欧美第一黄网免费网站| 欧美视频官网| 一本色道久久综合亚洲精品不| 亚洲激情网站| 一区二区三区|亚洲午夜| 欧美成人一品| 亚洲九九精品| 亚洲一区二区三区免费观看| 国产精品麻豆va在线播放| 亚洲影院免费| 久久午夜色播影院免费高清| 在线看日韩av| 欧美高潮视频| 国产精品99久久久久久久久久久久| 亚洲视频播放| 国产视频欧美视频| 老鸭窝亚洲一区二区三区| 亚洲电影免费| 亚洲一区3d动漫同人无遮挡| 国产精品免费网站| 久久免费国产精品| 日韩一级免费| 久久夜色精品国产亚洲aⅴ| 亚洲欧洲在线一区| 国产精品久久久久秋霞鲁丝| 欧美一级一区| 亚洲人久久久| 久久久久久9| 一区二区激情小说| 国产专区一区| 欧美日韩在线免费视频| 久久国产精品72免费观看| 91久久国产综合久久91精品网站| 亚洲免费影院| 亚洲激情不卡| 国产欧美日韩在线视频| 欧美成年视频| 欧美一区二区三区视频免费| 亚洲国产欧美日韩精品| 欧美一区二区三区视频在线观看| 亚洲高清影视| 国产精品一区二区久久| 欧美精品aa| 久久久青草青青国产亚洲免观| 99亚洲视频| 欧美黄色大片网站| 久久久精品一品道一区| 亚洲在线观看免费| 9人人澡人人爽人人精品| 激情久久久久久| 国产精品一区一区三区| 欧美日韩一区二区三区四区在线观看 | 国产欧美日韩不卡| 欧美日韩视频在线观看一区二区三区 | 99re8这里有精品热视频免费 | 久久免费少妇高潮久久精品99| 在线中文字幕日韩| 亚洲国产一区在线观看| 激情综合色综合久久综合| 国产精品自拍在线| 欧美视频在线观看免费网址| 欧美国产日韩一区二区三区| 久久伊伊香蕉| 久色成人在线| 久久视频精品在线| 久久精品视频免费| 久久国产精品亚洲77777| 欧美一级久久| 欧美一区视频| 欧美中文在线免费| 久久久久成人网| 久久久精品欧美丰满| 久久精品国产清自在天天线| 欧美一区二区三区四区在线| 午夜激情综合网| 欧美在线日韩| 久久免费视频在线观看| 久久影视三级福利片| 久久天天狠狠| 欧美成人高清视频| 欧美日韩精品在线播放| 欧美日韩一区二区三| 国产精品久久久久aaaa| 国产精品男人爽免费视频1| 国产精品外国| 韩国三级电影一区二区| 在线观看av不卡| 亚洲免费电影在线| 亚洲自拍电影| 久久久国产亚洲精品| 免费亚洲电影在线观看| 最新日韩av| 亚洲一区二区免费| 久久久久久亚洲综合影院红桃| 久热精品在线| 国产精品白丝黑袜喷水久久久| 国产精品视频网站| 影音先锋中文字幕一区| 亚洲另类一区二区| 香蕉国产精品偷在线观看不卡 | 亚洲电影免费观看高清完整版在线 | 在线 亚洲欧美在线综合一区| 亚洲国产经典视频| 亚洲午夜激情网页| 久久精品一区二区| 亚洲黄色免费电影| 亚洲永久免费av| 农村妇女精品| 国产日产欧美a一级在线| 影音先锋亚洲电影| 亚洲尤物在线| 欧美激情网友自拍| 亚洲综合色视频| 欧美成人免费大片| 国产伪娘ts一区| 99视频有精品| 鲁大师成人一区二区三区| 一区二区三区 在线观看视| 久久久久久久久久久久久久一区| 欧美日韩国产另类不卡| 精品91在线| 欧美一级成年大片在线观看| 欧美高清视频在线| 性做久久久久久久久| 欧美日韩精品欧美日韩精品一 | 狠狠色2019综合网| 午夜日韩av| 亚洲日本成人网| 久久资源av| 激情久久五月| 久久久一区二区| 午夜在线播放视频欧美| 欧美色图天堂网| aa亚洲婷婷| 亚洲黑丝在线|