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

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 閱讀(2936) 評論(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>
            亚洲欧美日韩国产综合| 亚洲视频一二区| 免费看成人av| 久久久久久久久久久久久9999| 午夜精品在线观看| 欧美一区三区三区高中清蜜桃| 亚洲你懂的在线视频| 午夜精品久久久久久久久久久久久| 亚洲欧美制服另类日韩| 欧美亚洲一区二区在线观看| 欧美一区二区成人| 久久综合导航| 欧美午夜精品久久久久久久| 国产精品一级| 精品成人在线视频| 亚洲乱码一区二区| 香蕉精品999视频一区二区 | 最新热久久免费视频| 一二美女精品欧洲| 欧美在线欧美在线| 91久久夜色精品国产九色| 亚洲国产精品毛片| 亚洲一区二区三区中文字幕| 性xx色xx综合久久久xx| 欧美激情a∨在线视频播放| 国产精品久久| 亚洲国产成人精品女人久久久| 夜夜嗨av一区二区三区网页| 亚洲视频碰碰| 美玉足脚交一区二区三区图片| 亚洲剧情一区二区| 久久精品视频在线| 欧美日韩一区二区三区在线看 | 亚洲精品偷拍| 久久爱www.| 亚洲精品国产品国语在线app| 亚洲一级二级| 久久亚洲欧美国产精品乐播| 亚洲免费av片| 麻豆精品视频| 国产亚洲亚洲| 亚洲一级黄色片| 欧美高清视频一区二区| 亚洲欧美激情诱惑| 欧美精品黄色| **性色生活片久久毛片| 欧美一区二区三区啪啪| 一本久久知道综合久久| 欧美高清成人| 91久久精品一区二区别| 蜜桃av综合| 久久精品一区蜜桃臀影院| 国产精品永久免费在线| 亚洲一区二区精品在线| 亚洲精品日本| 欧美精品在线视频观看| 亚洲欧洲日产国产网站| 欧美成人蜜桃| 久久综合久久久久88| 在线播放不卡| 欧美成人中文| 美女主播一区| 亚洲精品在线一区二区| 91久久精品日日躁夜夜躁欧美| 欧美大成色www永久网站婷| 亚洲日本欧美日韩高观看| 亚洲国产成人av| 欧美国产日韩二区| 国产精品99久久99久久久二8 | 老司机精品导航| 亚洲国产精品欧美一二99| 欧美成人蜜桃| 欧美高清在线播放| 亚洲少妇最新在线视频| 一本色道久久综合亚洲精品高清 | 亚洲国产专区校园欧美| 欧美国产精品一区| 欧美日韩亚洲不卡| 欧美在线啊v一区| 久久久亚洲国产天美传媒修理工| 亚洲国内自拍| 99在线精品视频| 国产欧美日韩一区二区三区在线观看| 欧美一区二区大片| 噜噜噜噜噜久久久久久91| 夜夜嗨av色综合久久久综合网| 亚洲一区黄色| 亚洲二区在线观看| 9人人澡人人爽人人精品| 国产精品天天摸av网| 欧美jjzz| 欧美三区在线视频| 欧美一区免费视频| 亚洲欧洲日产国产综合网| 久久久久国色av免费观看性色| 国产日韩在线视频| 美女诱惑黄网站一区| 欧美日韩国产高清| 久久国产婷婷国产香蕉| 欧美电影免费观看高清完整版| 亚洲男人的天堂在线| 久久久精品网| 亚洲免费在线观看| 老司机aⅴ在线精品导航| 亚洲一级在线观看| 久久综合久久综合久久| 亚洲欧美资源在线| 欧美激情精品久久久| 久久久噜噜噜久久| 国产精品捆绑调教| 亚洲人在线视频| 精品99视频| 亚洲一区二区三区在线播放| av不卡在线看| 美女脱光内衣内裤视频久久影院| 香蕉久久精品日日躁夜夜躁| 欧美激情第9页| 欧美3dxxxxhd| 国内精品写真在线观看| 亚洲一区二区三区涩| 一区二区高清视频| 欧美激情aaaa| 亚洲国产精品热久久| 在线日韩电影| 久久久久9999亚洲精品| 欧美专区日韩专区| 国产精品系列在线播放| 日韩视频在线免费观看| 日韩视频永久免费| 欧美大片免费久久精品三p | 久久精品欧美日韩精品| 欧美性猛交xxxx乱大交蜜桃| 亚洲欧洲另类国产综合| 最新国产の精品合集bt伙计| 久久夜色精品国产| 麻豆国产va免费精品高清在线| 国产一区二区无遮挡| 久久成人人人人精品欧| 久久久久久尹人网香蕉| 黑人一区二区三区四区五区| 欧美一区二区三区视频免费播放| 欧美在线观看你懂的| 国产日韩精品入口| 欧美一区视频| 欧美成年人视频| 亚洲精品国久久99热| 欧美屁股在线| 中文在线一区| 欧美在线3区| 伊人精品成人久久综合软件| 久久综合色一综合色88| 亚洲黄色尤物视频| 亚洲图片在线| 国产农村妇女毛片精品久久麻豆| 午夜精品福利在线观看| 欧美亚洲日本网站| 影音先锋另类| 欧美理论电影在线播放| 正在播放欧美一区| 国产精品初高中精品久久| 亚洲国产美国国产综合一区二区| 国产无一区二区| 久久精品亚洲| 亚洲人体一区| 欧美中文字幕精品| 亚洲国产天堂久久综合网| 欧美日韩另类综合| 性视频1819p久久| 欧美激情第1页| 亚洲一区二区三区高清| 国产午夜亚洲精品理论片色戒| 久久久国产一区二区三区| 亚洲精品久久久久久久久| 欧美一区不卡| 亚洲精品小视频在线观看| 国产精品美女久久久久久久 | 一二三四社区欧美黄| 久久精品综合网| 日韩午夜av| 国产视频观看一区| 欧美激情一区二区三区四区| 亚洲女人天堂成人av在线| 免费成人黄色av| 午夜在线观看免费一区| 亚洲精品一区二区在线观看| 国产日产亚洲精品| 欧美成人精品福利| 欧美一级专区| 日韩午夜三级在线| 欧美成人综合在线| 久久成人精品视频| 一本到高清视频免费精品| 激情自拍一区| 国产欧美日韩精品丝袜高跟鞋 | 欧美一区二区三区四区在线观看地址 | 久久av一区二区| 亚洲午夜久久久久久久久电影院| 亚洲第一在线综合网站| 国产毛片精品视频| 国产精品进线69影院|