自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C++ Builder操作Excel表實(shí)現(xiàn)技巧講解

開(kāi)發(fā) 后端
我們今天將會(huì)為大家詳細(xì)介紹一下有關(guān)C++ Builder操作Excel表的相關(guān)操作方法。希望剛剛接觸這款語(yǔ)言的朋友們能從中獲得一些幫助。

C++編程語(yǔ)言應(yīng)用范圍廣泛,可以幫助我們輕松的實(shí)現(xiàn)各種功能需求。比如今天為大家接受的對(duì)Excel表的操作。那么接下來(lái)我們就一起來(lái)看看C++ Builder操作Excel表的相關(guān)實(shí)現(xiàn)方法。希望能夠?yàn)榇蠹規(guī)?lái)一些幫助。#t#

Microsoft Excel作為一個(gè)功能強(qiáng)大的電子表格處理軟件,已經(jīng)得到了廣泛的應(yīng)用。在數(shù)據(jù)庫(kù)應(yīng)用軟件開(kāi)發(fā)過(guò)程中,如果能實(shí)現(xiàn)數(shù)據(jù)庫(kù)與Excel文件的數(shù)據(jù)交換,那么一方面能增加數(shù)據(jù)庫(kù)數(shù)據(jù)的來(lái)源,另一方面也能方便用戶對(duì)數(shù)據(jù)庫(kù)數(shù)據(jù)的進(jìn)一步處理。

C++ Builder是一個(gè)可視化快速應(yīng)用程序開(kāi)發(fā)工具,它提供的OLE Automation機(jī)制使得開(kāi)發(fā)人員在應(yīng)用程序中就能調(diào)用Excel,實(shí)現(xiàn)數(shù)據(jù)交換。

在C++ Builder中調(diào)用Excel,首先要為Excel建立一個(gè)OLE對(duì)象,然后通過(guò)設(shè)定該對(duì)象的屬性和調(diào)用該對(duì)象的方法來(lái)操縱Excel。C++ Builder通過(guò)CreateOleObject()來(lái)建立OLE對(duì)象;用OlePropertySet(propname,value)來(lái)設(shè)置OLE對(duì)象的屬性;用OlePropertyGet(propname)獲得OLE對(duì)象的屬性;通過(guò)OleFunction(oleFuncName,[val,...])和OleProcedure(oleProcName,[val,...])來(lái)調(diào)用OLE對(duì)象的方法。

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

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

  1. Variant ex,newxls;   
  2. int i,j=1;   
  3. try   
  4. {   
  5. ex=CreateOleObject(″Excel.Application″); //啟動(dòng)Excel   
  6. }   
  7. catch(...)   
  8. {   
  9. ShowMessage(″無(wú)法啟動(dòng)Excel″);   
  10. }   
  11. ex.OlePropertySet(″Visible″,(Variant)true); //使Excel啟動(dòng)后可見(jiàn)   
  12. newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);
    //新建一個(gè)工作薄   
  13. Table1-〉Active=true;   
  14. //打開(kāi)數(shù)據(jù)庫(kù)   
  15. Table1-〉First();   
  16. for(i=0;i〈Table1-〉FieldCount;i++)   
  17. //將字段名寫(xiě)到工作薄的***行   
  18. {   
  19. (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,
    (Variant)(i+1),(Variant)Table1-〉Fields[i]-〉FieldName);   
  20. }   
  21. while(!Table1-〉Eof)   
  22. //將數(shù)據(jù)庫(kù)中的記錄依次寫(xiě)到工作薄中   
  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]-〉A(chǔ)sString);   
  29. }   
  30. Table1-〉Next();   
  31. }   
  32. newxls.OleFunction(″SaveAs″,(Variant)filename);   
  33. //保存工作薄,filename是工作薄的全文件名   
  34. ex.OleFunction(″Quit″);   
  35. //退出Excel,釋放OLE對(duì)象  

 

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

運(yùn)行程序就可以實(shí)現(xiàn)將數(shù)據(jù)庫(kù)中的數(shù)據(jù)轉(zhuǎn)換到Excel工作薄中。同樣的道理,使用OlePropertyGet()函數(shù),也可以將Excel工作薄中的數(shù)據(jù)讀到數(shù)據(jù)庫(kù)中去。

以上C++ Builder操作Excel表代碼在Windows 98操作系統(tǒng)、C++ Builder 3.0下調(diào)試運(yùn)行通過(guò)。

責(zé)任編輯:曹凱 來(lái)源: 博客園
相關(guān)推薦

2010-02-01 15:01:34

C++拋出異常

2010-02-06 15:49:31

刪除C++容器值

2010-02-05 13:52:04

C++資源管理

2010-02-01 17:37:35

C++調(diào)用C鏈接庫(kù)

2010-01-22 16:21:50

C++ Builder

2009-09-10 10:59:47

C# form

2010-02-01 17:09:07

C++鏈表操作

2009-12-04 15:52:46

PHP導(dǎo)入Excel文

2010-01-15 09:58:38

C++ Builder

2010-01-26 14:10:22

Visual C++

2010-02-02 17:13:35

C++ Endian

2011-05-30 15:29:32

C++

2009-08-25 16:49:28

.NET Excel

2010-01-04 14:49:30

Silverlight

2010-02-04 11:38:43

C++獲取當(dāng)前路徑

2010-02-03 09:43:16

C++單例模式

2009-09-01 13:59:01

C#操作Excel

2011-07-10 15:26:54

C++

2010-01-22 16:35:41

C++開(kāi)發(fā)

2010-01-26 17:11:13

C++編程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)