• <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>

            飛天

            快樂的生活......

             

            Bcb中的Excel操作類

                  最近做一個專案,要求能將Excel表中的數(shù)據(jù)轉(zhuǎn)入數(shù)據(jù)庫,反之將數(shù)據(jù)庫的內(nèi)容導(dǎo)入到Excel表中。看了網(wǎng)上寫的關(guān)于操作Excel的方法,寫了一個簡單的Excel操作類。功能還不是很完善,以后再慢慢修改。 
                
            ***********************************************************************
             
            * Module:  TExcel.cpp
             
            * Author:  cjz
             
            * Modified: 2007-07-29日 11:07:30
             
            * Purpose: Implementation of the class TExcel
             
            * Comment: Excel巨摸
             
            ***********************************************************************/

            #include 
            <vcl.h>
            #include 
            "TExcel.h"
            #include 
            "vcl\utilcls.h"

            ////////////////////////////////////////////////////////////////////////
            // Name:       TExcel::TExcel()
            // Purpose:    Implementation of TExcel::TExcel()
            // Return:
            ////////////////////////////////////////////////////////////////////////

            TExcel::TExcel()
            {
                    Sheet
            =new TSheet();
                NewExcel();
            }


            ////////////////////////////////////////////////////////////////////////
            // Name:       TExcel::TExcel(AnsiString m_strFile)
            // Purpose:    Implementation of TExcel::TExcel()
            // Comment:    帶參數(shù)的構(gòu)造函數(shù)
            // Parameters:
            // - m_strFile
            // Return:
            ////////////////////////////////////////////////////////////////////////

            TExcel::TExcel(AnsiString m_strFile)
            {
               strFileName
            =m_strFile;
               Sheet
            =new TSheet();
               OpenExcel();
               
            }


            ////////////////////////////////////////////////////////////////////////
            // Name:       TExcel::~TExcel()
            // Purpose:    Implementation of TExcel::~TExcel()
            // Return:     
            ////////////////////////////////////////////////////////////////////////

            TExcel::
            ~TExcel()
            {
               
            //CloseExcel();
            }


            ////////////////////////////////////////////////////////////////////////
            // Name:       TExcel::OpenExcel()
            // Purpose:    Implementation of TExcel::OpenExcel()
            // Return:     bool
            ////////////////////////////////////////////////////////////////////////

            bool __fastcall TExcel::OpenExcel(void)
            {
               
            if(!FileExists(strFileName))
               
            {
                 MessageDlg(
            "ゅンぃ!",
                         mtWarning, TMsgDlgButtons() 
            << mbOK, 0);
                 
            return false;
               }

               
            try
               
            {
                   CoInitialize(NULL);
                   vEx
            =CreateOleObject("Excel.Application");
                   vEx.OPS(
            "Visible",false);
                   vEx.OPG(
            "WorkBooks").OPR("Open",strFileName.c_str());
                   vWb
            =vEx.OPG("ActiveWorkBook");
                   vSh
            =vWb.OPG("ActiveSheet");

                       nSheetCount
            =vWb.OPG("sheets").OPG("count");

               }

               
            catch()
               
            {
                    ShowMessage(
            "礚猭幣笆Excel,琌⊿Τ桿!");
                     
            return false;
               }

               
            return true;
            }


            ////////////////////////////////////////////////////////////////////////
            // Name:       TExcel::NewExcel()
            // Purpose:    Implementation of TExcel::NewExcel()
            // Return:     bool
            ////////////////////////////////////////////////////////////////////////

            bool __fastcall TExcel::NewExcel(void)
            {
               
            try
               
            {
                       CoInitialize(NULL);
                   vEx
            =Variant::CreateObject("Excel.Application");
                   vEx.OPS(
            "Visible",false);
                   vEx.OPG(
            "WorkBooks").OFN("Add",1);
                   vWb
            =vEx.OPG("ActiveWorkBook");
                   vSh
            =vWb.OPG("ActiveSheet");

                       Sheet
            ->vSh=&vSh;
                       nSheetCount
            =1;

               }

               
            catch()
               
            {
                    ShowMessage(
            "礚猭幣笆Excel,琌⊿Τ桿!");
                     
            return false;
               }

               
            return true;
            }


            //---------------------------------------------------------------------
            //睰痢
            void __fastcall TExcel::AddSheet(AnsiString SheetName)
            {
                vEx.OPG(
            "WorkBooks").OFN("Add",1);
                nSheetCount
            =vWb.OPG("sheets").OPG("count");
                Sheets[nSheetCount]
            ->Name=SheetName;
            }

            ////////////////////////////////////////////////////////////////////////
            // Name:       TExcel::SaveExcel()
            // Purpose:    Implementation of TExcel::SaveExcel()
            // Return:     bool
            ////////////////////////////////////////////////////////////////////////

            bool  __fastcall TExcel::SaveExcel(void)
            {
               
            try
               
            {
                vWb.OFN(
            "save");
               }

               
            catch()
               
            {
                  MessageDlg(
            "玂Excelゅ郎ア毖!",
                        mtWarning, TMsgDlgButtons() 
            << mbOK, 0);
                     
            return false;
               }

               
            return true;

            }


            ////////////////////////////////////////////////////////////////////////
            // Name:       TExcel::SaveAsExcel()
            // Purpose:    Implementation of TExcel::SaveAsExcel()
            // Return:     bool
            ////////////////////////////////////////////////////////////////////////

            bool  __fastcall TExcel::SaveAsExcel(AnsiString fileName)
            {
               
            if(FileExists(fileName))
               
            {
                      
            if(MessageDlg("ゅン,琌灤籠?",mtConfirmation,TMsgDlgButtons()<<mbYes<<mbNo,0)==mrYes)
                      
            {
                          DeleteFile(fileName);
                      }

                      
            else
                      
            {
                            vWb.OPG(
            "Application").OPS("DisplayAlerts",false);
                            
            return false;
                      }

               }

               
            try
               
            {
                 vWb.OFN(
            "SaveAs",fileName.c_str());
               }

               
            catch()
               
            {
                     MessageDlg(
            "玂Excelゅ郎ア毖!",
                        mtWarning, TMsgDlgButtons() 
            << mbOK, 0);
                     
            return false;
               }

               
            return true;
            }


            ////////////////////////////////////////////////////////////////////////
            // Name:       TExcel::CloseExcel()
            // Purpose:    Implementation of TExcel::CloseExcel()
            // Return:     void
            ////////////////////////////////////////////////////////////////////////

            void  __fastcall TExcel::CloseExcel(void)
            {
               vWb.OFN(
            "close");
               vEx.OFN(
            "quit");

               vWb
            =Unassigned;
               vEx
            =Unassigned;
               CoUninitialize();
            }


            //---------------------------------------------------------------------
            //妮┦:莉材i茂
            TSheet *  __fastcall TExcel::GetSheet(int i)
            {
                
            //狦諷玡痢i,玥玥痢i
                if(i==nCurrSheet)
                   
            return Sheet;
                
            else
                   nCurrSheet
            =i;
                
            if(i<1||i>nSheetCount)
                    
            throw "ぃ茂"+i;
                vSh
            =vWb.OPG("Sheets",i);

                nRows
            =vSh.OPG("UsedRange").OPG("Rows").OPG("count");
                nColumns
            =vSh.OPG("UsedRange").OPG("Columns").OPG("count");

                Sheet
            ->nRows=nRows;
                Sheet
            ->nColumns=nColumns;
                Sheet
            ->vSh=&vSh;
                
            return Sheet;

            }
            暈死,變成亂碼。
            TExcel.h 文件頭

            工作表類:

            TSheet 文件頭

                   使用方法:
                 1.打開文件
                     TExcel *excel=new TExcel("要打開的文件名");
                 2.新建文件
                     TExcel *excel=new TExcel();
                 3.獲取工作薄n的單元格(i,j)
                     excel->Sheets[n]->GetCells(i,j);返回值是一個Varaint類型。
                 4.設(shè)置工作薄n的單元格(i,j)值
                    excel->Sheets[n]->SetCell(i,j,value);
                  5.獲取或設(shè)置工作薄名稱
                    excel->Sheets[n]->Name="...";或sheetname=excel->Sheets[n]->Name;
                  6.保存和另存為。
                   excel->SaveExcel();
                   excel->SaveAsExcel("新的文件名");
                  7.關(guān)閉
                   excel->CloseExcel();

            posted on 2007-08-03 10:29 飛天 閱讀(1556) 評論(0)  編輯 收藏 引用 所屬分類: C++Builder

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            Blogs

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            蜜臀久久99精品久久久久久小说| 久久精品国产亚洲AV香蕉| 93精91精品国产综合久久香蕉| 精品久久久久久久| 亚洲成av人片不卡无码久久| 中文字幕热久久久久久久| 国产精品毛片久久久久久久| 少妇被又大又粗又爽毛片久久黑人| 久久久久99这里有精品10 | 久久综合久久自在自线精品自| 久久91精品国产91久久小草| 伊色综合久久之综合久久| 精品久久久久久中文字幕人妻最新| 久久国产一片免费观看| 99国产欧美精品久久久蜜芽| 婷婷久久综合九色综合九七| 日本一区精品久久久久影院| 色婷婷久久综合中文久久蜜桃av| 久久精品成人| 97精品国产97久久久久久免费| 日韩人妻无码精品久久久不卡| 欧美色综合久久久久久 | 一级a性色生活片久久无少妇一级婬片免费放| 久久久无码精品亚洲日韩京东传媒| 久久精品国产亚洲一区二区| 久久综合九色综合网站| 亚洲va久久久噜噜噜久久男同| 久久久久久国产精品免费免费| 精品精品国产自在久久高清| 人妻少妇久久中文字幕| 亚洲国产精品无码成人片久久| 亚洲精品视频久久久| 无码人妻少妇久久中文字幕 | 亚洲va久久久噜噜噜久久| 一本久久综合亚洲鲁鲁五月天| 久久久久国产一级毛片高清板| 国产成人无码精品久久久免费| 狠狠干狠狠久久| 狠狠久久综合伊人不卡| 久久无码人妻精品一区二区三区| 久久中文字幕无码专区|