日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
C++Builder操作Excel表實(shí)現(xiàn)技巧講解

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

站在用戶的角度思考問題,與客戶深入溝通,找到廣西網(wǎng)站設(shè)計(jì)與廣西網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站制作、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名申請、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋廣西地區(qū)。

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

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

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

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

首先新建一個(gè)表單Form1,保存單元文件Unit1.cpp,保存工程文件Project1.bpr。然后在表單中加入數(shù)據(jù)訪問控件TTable,將Name屬性設(shè)為Table1,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. ex=CreateOleObject(″Excel.Application″); //啟動Excel 
  5. catch(...) 
  6. ShowMessage(″無法啟動Excel″); 
  7. ex.OlePropertySet(″Visible″,(Variant)true); //使Excel啟動后可見 
  8. newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);
    //新建一個(gè)工作薄 
  9. Table1-〉A(chǔ)ctive=true; 
  10. //打開數(shù)據(jù)庫 
  11. Table1-〉First(); 
  12. for(i=0;i〈Table1-〉FieldCount;i++) 
  13. //將字段名寫到工作薄的***行 
  14. (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,
    (Variant)(i+1),(Variant)Table1-〉Fields[i]-〉FieldName); 
  15. while(!Table1-〉Eof) 
  16. //將數(shù)據(jù)庫中的記錄依次寫到工作薄中 
  17. jj=j+1; 
  18. for(i=0;i〈Table1-〉FieldCount;i++) 
  19. (ex.OleFunction(″Cells″)).OlePropertySet
    (″Item″,(Variant)j,(Variant)(i+1), 
  20. (Variant)Table1-〉Fields[i]-〉A(chǔ)sString); 
  21. Table1-〉Next(); 
  22. newxls.OleFunction(″SaveAs″,(Variant)filename); 
  23. //保存工作薄,filename是工作薄的全文件名 
  24. ex.OleFunction(″Quit″); 
  25. //退出Excel,釋放OLE對象 

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

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

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


本文名稱:C++Builder操作Excel表實(shí)現(xiàn)技巧講解
新聞來源:http://www.5511xx.com/article/djpogge.html