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

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 閱讀(2947) 評論(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>
            你懂的一区二区| 亚洲人成网在线播放| 99视频精品在线| 欧美日韩欧美一区二区| 99re66热这里只有精品4| 欧美激情精品久久久久久免费印度 | 日韩视频免费| 99视频精品| 国产美女高潮久久白浆| 久久婷婷av| 牛牛影视久久网| 中国亚洲黄色| 午夜天堂精品久久久久| 激情成人综合| 亚洲片国产一区一级在线观看| 欧美成人一区二区三区| 亚洲一区二区免费视频| 性欧美在线看片a免费观看| 激情婷婷亚洲| 亚洲精品小视频| 国产欧美日韩视频一区二区三区| 久久免费高清| 欧美激情在线免费观看| 亚洲欧美色婷婷| 久久婷婷av| 亚洲主播在线观看| 久久久噜噜噜| 亚洲伊人久久综合| 久久精品中文字幕免费mv| 亚洲精品乱码久久久久久按摩观| 亚洲免费不卡| 黄色日韩在线| 亚洲最新视频在线| 在线观看亚洲一区| 中文一区二区在线观看| 亚洲第一页中文字幕| 在线视频日韩精品| 亚洲欧洲精品一区二区三区不卡 | 欧美人与禽猛交乱配视频| 亚洲综合国产激情另类一区| 久久精品水蜜桃av综合天堂| 亚洲理论在线| 久久精品视频va| 亚洲欧美成人一区二区在线电影| 久久人人97超碰精品888| 午夜精彩视频在线观看不卡 | 久久精品综合| 亚洲一区二区三区四区五区黄 | 一区二区三区国产| 亚洲黄页视频免费观看| 欧美影院在线| 午夜影院日韩| 欧美体内谢she精2性欧美| 欧美肥婆在线| 国产揄拍国内精品对白| 宅男在线国产精品| 亚洲最新在线视频| 欧美成人精品一区二区三区| 久久久久久伊人| 国产欧美日韩另类一区| 一区二区高清在线观看| 日韩午夜免费| 欧美mv日韩mv国产网站| 欧美不卡高清| 国内欧美视频一区二区| 性欧美18~19sex高清播放| 午夜在线一区二区| 国产精品久久久久久久久搜平片| 最新国产乱人伦偷精品免费网站| 亚洲福利免费| 免费成人av| 欧美成人资源| 亚洲免费观看高清完整版在线观看熊 | 欧美区国产区| 亚洲精品久久久久久久久久久| 亚洲第一中文字幕在线观看| 久久精品综合网| 欧美顶级艳妇交换群宴| 亚洲精品一区在线| 欧美片网站免费| 亚洲特黄一级片| 久久爱www.| 在线成人激情黄色| 免费视频一区| 一本色道久久综合狠狠躁篇的优点 | 久久久伊人欧美| 亚洲国产高清一区二区三区| 欧美成人高清视频| 99re成人精品视频| 性高湖久久久久久久久| 国产亚洲精品福利| 鲁大师成人一区二区三区| 亚洲高清影视| 亚洲一区二区欧美| 国产精品免费电影| 久久久激情视频| 亚洲经典在线看| 亚洲欧美bt| 在线观看视频亚洲| 欧美日韩一区二区三区在线观看免 | 欧美有码在线观看视频| 一区二区在线不卡| 欧美剧在线观看| 欧美有码在线视频| 亚洲三级电影在线观看| 久久久精品国产免大香伊| 最新日韩精品| 国产综合色一区二区三区| 欧美国产综合视频| 久久国产精品久久久久久久久久| 亚洲国产午夜| 久久全国免费视频| 亚洲一区美女视频在线观看免费| 伊人精品久久久久7777| 国产精品分类| 欧美黄色aaaa| 久久久久.com| 亚洲欧美日韩在线| 亚洲免费不卡| 亚洲国产精品悠悠久久琪琪| 久久成人这里只有精品| 制服诱惑一区二区| 在线欧美福利| 国产日韩精品入口| 欧美三区在线观看| 欧美成人中文字幕在线| 久久精品中文字幕一区二区三区 | 欧美韩日精品| 久久青草久久| 久久精品91久久久久久再现| 一区二区三区久久网| 亚洲激情小视频| 精品99视频| 国内精品久久久久影院优| 国产精品久久综合| 欧美午夜大胆人体| 欧美日韩免费一区二区三区视频| 免费观看国产成人| 久久一区二区精品| 久久精品水蜜桃av综合天堂| 欧美一区二区三区久久精品茉莉花 | 欧美成人精品一区二区三区| 久久精品二区| 久久久99爱| 久久久久久夜| 麻豆91精品91久久久的内涵| 久久免费高清| 你懂的成人av| 欧美国产综合| 最新国产の精品合集bt伙计| 亚洲国产精品美女| 亚洲国产一区二区三区a毛片| 欧美激情va永久在线播放| 美女视频黄 久久| 欧美成人免费大片| 亚洲国产成人精品久久| 亚洲国产人成综合网站| 亚洲日韩欧美视频一区| 一区二区三区视频在线观看| 亚洲午夜一区二区三区| 午夜天堂精品久久久久| 久久人人爽人人爽爽久久| 老鸭窝毛片一区二区三区 | 亚洲欧美国产精品专区久久| 亚洲一区二区三区在线视频| 亚洲欧美日本国产专区一区| 小黄鸭精品密入口导航| 久久久噜噜噜| 欧美日韩亚洲视频| 国产欧美日韩一区二区三区在线| 国产一区二区三区四区| 亚洲激情六月丁香| 亚洲一级在线| 久久婷婷成人综合色| 亚洲人成在线播放| 亚洲综合视频网| 久久色在线播放| 欧美日韩在线三区| 黄色亚洲在线| 亚洲深夜福利| 久久一区激情| 一本大道久久a久久综合婷婷 | 99热精品在线观看| 欧美在线亚洲在线| 欧美精品激情在线| 国内精品视频一区| 99成人在线| 久久精品视频免费观看| 亚洲激情社区| 欧美在线资源| 欧美网站在线观看| 亚洲国产精品久久精品怡红院| 亚洲午夜视频| 欧美激情精品久久久久久久变态 | 亚洲国产婷婷香蕉久久久久久99| 亚洲在线视频观看| 欧美国产亚洲另类动漫| 国产亚洲欧美一区在线观看| 一级日韩一区在线观看| 免费久久99精品国产|