zoukankan      html  css  js  c++  java
  • COM对EXCEL操作

    运用该方法需要添加六个文件,网上可以找到,即:excel.tlh、excel.tli、mso.tlh、mso.tli、vbe6ext.tlh、vbe6ext.tli

    CString strFilter=_T("Excel文件(*.xls, *.xlsx)|*.xls;*.xlsx||"); //|All files (*.*)|*.*||";
    CFileDialog dlg(TRUE,NULL,NULL,OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,
    strFilter);
    CString strFilePath;
    if (dlg.DoModal()==IDOK)
    {
    strFilePath=dlg.GetPathName();
    if (strFilePath.IsEmpty())
    {
    MessageBox(_T("选择相应文件为空!"),_T("提示"));
    return;
    }
    }
    else
    {
    return;
    }
    m_lstLibMaterial.DeleteAllItems();
    //下面对Excel表进行操作
    strFilePath.Format(L"%s",strFilePath);
    _bstr_t filePath=(_bstr_t)strFilePath;
    CoInitializeEx( 0, COINIT_APARTMENTTHREADED );
    Excel::_ApplicationPtr xApp;
    Excel::RangePtr rang;
    xApp.CreateInstance(__uuidof(Excel::Application));
    Excel::_WorkbookPtr xBook = xApp->Workbooks->Open(filePath);//工作区
    int numSheet=xApp->Sheets->GetCount();
    CString strCol;

    _variant_t varTmp;

    CLastMaterialInfoBase *data=NULL;
    char *buf=NULL;

    buf = new char[128];
    int iNum=0;
    int rowNum;
    int nrow;
    CString str;
    CString strText;
    _bstr_t text;
    m_lstLibMaterial.SetRedraw(FALSE);
    for (int ii=1;ii<=numSheet;ii++)//目前只考虑一个表单
    {
    Excel::_WorksheetPtr xSheet=xApp->Sheets->GetItem(ii);
    rowNum=xSheet->UsedRange->Rows->Count;//被使用行数
    int colNum=xSheet->UsedRange->Columns->Count;//列数
    for (int jj=2;jj<=rowNum;jj++)
    {
    str.Format(_T("%d行"),jj);
    //DebugOutStr(str);
    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("G%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    //DebugOutStr(_T("执行2"));
    if (strText.IsEmpty())
    {
    continue;
    }
    m_lstLibMaterial.InsertItem(0,_T(""));
    m_lstLibMaterial.SetItemText(0,0,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("I%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,1,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("J%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,2,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("C%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,3,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("A%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,4,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("K%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,5,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("N%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,6,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("O%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,7,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("P%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,8,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("Q%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,9,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("R%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,10,strText);

    strText.Empty();
    strCol.Empty();
    strCol.Format(_T("S%d"),jj);
    varTmp=(LPCTSTR)strCol;
    strText=xSheet->Range[varTmp][vtMissing]->Text;
    m_lstLibMaterial.SetItemText(0,11,strText);
    }

    }
    m_lstLibMaterial.SetRedraw(TRUE);
    xApp->Workbooks->Close();
    xApp->Quit();

  • 相关阅读:
    下雪诗
    华视身份证阅读器100UC HTTP模式二次开发
    C# Action 和 Func 区别
    网站部署——文件系统
    前端-JavaScript DOM和BOM
    IO多路复用
    python-协程
    python-线程
    python-进程
    计算机与操作系统简介
  • 原文地址:https://www.cnblogs.com/lishennan/p/4583913.html
Copyright © 2011-2022 走看看