程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> C++ Builder操作Excel表實現技巧講解

C++ Builder操作Excel表實現技巧講解

編輯:C++入門知識

C++編程語言應用范圍廣泛,可以幫助我們輕松的實現各種功能需求。比如今天為大家接受的對Excel表的操作。那麼接下來我們就一起來看看C++ Builder操作Excel表的相關實現方法。希望能夠為大家帶來一些幫助。

  • 幾種不同C++繼承方式簡介
  • C++標准輸入輸出應用技巧解析
  • C++初始化和賦值區別解析
  • C++頭文件包含內容概覽
  • C++指針漂移問題解決方案

Microsoft Excel作為一個功能強大的電子表格處理軟件,已經得到了廣泛的應用。在數據庫應用軟件開發過程中,如果能實現數據庫與Excel文件的數據交換,那麼一方面能增加數據庫數據的來源,另一方面也能方便用戶對數據庫數據的進一步處理。

C++ Builder是一個可視化快速應用程序開發工具,它提供的OLE Automation機制使得開發人員在應用程序中就能調用Excel,實現數據交換。

在C++ Builder中調用Excel,首先要為Excel建立一個OLE對象,然後通過設定該對象的屬性和調用該對象的方法來操縱Excel。C++ Builder通過CreateOleObject()來建立OLE對象;用OlePropertySet(propname,value)來設置OLE對象的屬性;用OlePropertyGet(propname)獲得OLE對象的屬性;通過OleFunction(oleFuncName,[val,...])和OleProcedure(oleProcName,[val,...])來調用OLE對象的方法。

C++ Builder中使用OLE自動化操縱Excel,必須掌握Excel的自動化對象及VBA關於Excel的對象方法和屬性,這些都在Microsoft Office(完全安裝)的VBAXL8.HLP幫助文件中可以找到,在此就不再贅述。下面以將數據庫中的數據轉到Excel工作薄中為例,說明C++ Builder操作Excel表的具體方法。

首先新建一個表單Form1,保存單元文件Unit1.cpp,保存工程文件Project1.bpr。然後在表單中加入數據訪問控件TTable,將Name屬性設為Table1,DatabaseName屬性設為BCDEMOS,TableName屬性設為Country.db。在表單中加入一個按鈕控件TButton,將其Name屬性設為Button1,Caption屬性設為 “轉換為Excel文件”。雙擊Button1,在Button1Click()函數中加入如下代碼:

  1. Variant ex,newxls;   
  2. int i,j=1;   
  3. try   
  4. {   
  5. ex=CreateOleObject(″Excel.Application″); //啟動Excel   
  6. }   
  7. catch(...)   
  8. {   
  9. ShowMessage(″無法啟動Excel″);   
  10. }   
  11. ex.OlePropertySet(″Visible″,(Variant)true); //使Excel啟動後可見   
  12. newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);
    //新建一個工作薄   
  13. Table1-〉Active=true;   
  14. //打開數據庫   
  15. Table1-〉First();   
  16. for(i=0;i〈Table1-〉FieldCount;i++)   
  17. //將字段名寫到工作薄的第一行   
  18. {   
  19. (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,
    (Variant)(i+1),(Variant)Table1-〉Fields[i]-〉FieldName);   
  20. }   
  21. while(!Table1-〉Eof)   
  22. //將數據庫中的記錄依次寫到工作薄中   
  23. {   
  24. jj=j+1;   
  25. for(i=0;i〈Table1-〉FieldCount;i++)   
  26. {   
  27. (ex.OleFunction(″Cells″)).OlePropertySet
    (″Item″,(Variant)j,(Variant)(i+1),   
  28. (Variant)Table1-〉Fields[i]-〉AsString);   
  29. }   
  30. Table1-〉Next();   
  31. }   
  32. newxls.OleFunction(″SaveAs″,(Variant)filename);   
  33. //保存工作薄,filename是工作薄的全文件名   
  34. ex.OleFunction(″Quit″);   
  35. //退出Excel,釋放OLE對象  

注意,要使用OLE自動化對象,在編譯之前還必須在Unit1.cpp文件前面加上#include ″ComObj.hpp″。

運行程序就可以實現將數據庫中的數據轉換到Excel工作薄中。同樣的道理,使用OlePropertyGet()函數,也可以將Excel工作薄中的數據讀到數據庫中去。

以上C++ Builder操作Excel表代碼在Windows 98操作系統、C++ Builder 3.0下調試運行通過。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved