亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 20000806011.htm

?? C++ Builder學(xué)習(xí)中文版,讓學(xué)者對(duì)其有一定的理解.
?? HTM
字號(hào):
<HTML>

<HEAD>



<TITLE>用C++Builder存取Excel</TITLE>



<META content="MSHTML 5.00.2314.1000" name=GENERATOR>

</HEAD>

<BODY aLink=#FF0000 bgColor=#ffffff leftMargin=0 link=#187800 topMargin=0 

vLink=#990099>



<div align="center">

  <table width="744" border="0" cellspacing="0" cellpadding="0" height="76">

    <tr> 

      <td> 

        <p align="center"><span style="FONT-SIZE: 9pt"><strong><font size="3"><br>

          用C++Builder存取Excel</font></strong></span></p>

        <p>--- C++Builder是Borland公司繼Delphi之后又一成功的產(chǎn)品,她集VB、VC++ 及 Delphi 的優(yōu)點(diǎn)于一體而深得C語(yǔ)言愛(ài)好者的青睞。由于多數(shù)操作者愛(ài)用 

          MicroSoft公司的Excel組織數(shù)據(jù),為此本文介紹了用C++Builder存取Excel 文件的兩種方法。<br>

          <br>

          ---- 一.用OLE技術(shù)操縱Excel<br>

          <br>

          ---- OLE(對(duì)象鏈接與嵌入)是微軟提出的標(biāo)準(zhǔn),是應(yīng)用程序間交換數(shù)據(jù)、相互操作的一種方式,MS OFFICE 提供了很強(qiáng)的 OLE 

          服務(wù)功能,VB、Delphi 及C++Builder等語(yǔ)言都可以以客戶方式向Excel提交命令,以存取其數(shù)據(jù),其中VB和Delphi最為簡(jiǎn)單,在語(yǔ)法上就采用類VBA的語(yǔ)句,本報(bào)九九年第48期的《在Delphi中操作Excel》一文曾介紹了Delphi的做法。我們?cè)詾镃++Builder照搬Delphi,結(jié)果語(yǔ)法編譯都未能通過(guò),查不到這方面具體介紹的資料。經(jīng)反復(fù)試驗(yàn)方知:原來(lái)C++Builder采用間接的辦法,利用變體類Variant所提供的四個(gè)“方法”向OLE服務(wù)程序提交操縱命令:<br>

          <br>

          Variant Variant::OlePropertyGet(屬性名,參數(shù)….);<br>

          // 取對(duì)象屬性<br>

          Void Variant::OlePropertySet(屬性名,參數(shù)….);<br>

          // 設(shè)置對(duì)象屬性<br>

          Variant Variant::OleFunction(函數(shù)名,參數(shù)….);<br>

          // 運(yùn)行對(duì)象的函數(shù)<br>

          void Variant::OleProcedure(過(guò)程名,參數(shù)….);<br>

          // 運(yùn)行對(duì)象的過(guò)程<br>

          <br>

          其頭文件“vcl\utilcls.h”必須嵌在用戶程序中,<br>

          對(duì)于這四個(gè)長(zhǎng)長(zhǎng)的方法名可在程序中用宏語(yǔ)句重新定義一下:<br>

          #define PG OlePropertyGet<br>

          #define PS OlePropertySet<br>

          #define FN OleFunction<br>

          #define PR OleProcedure<br>

          <br>

          例如對(duì)于VB的提交語(yǔ)句:<br>

          Ex.ActiveWorkBook.ActiveSheet.Cells(1,2).Value=3<br>

          為便于理解在C++Builder對(duì)應(yīng)的語(yǔ)句可分解為如下四句:<br>

          Variant t1=Ex.OlePropertyGet(&quot;ActiveWorkBook&quot;);<br>

          Variant t2=t1.OlePropertyGet(&quot;ActiveSheet&quot;);<br>

          Variant t3=t2.OlePropertyGet(&quot;Cells,1,2);<br>

          t3.OlePropertySet(&quot;Value&quot;,3);<br>

          可去掉中間變量將這四句合為一句,就是:<br>

          Ex.PG(&quot;ActiveWorkBook&quot;).PG(&quot;ActiveSheet&quot;).<br>

          PG(&quot;Cells&quot;,1,2).PS(&quot;Value&quot;,3);<br>

          我們將下面的VB程序片段改成對(duì)應(yīng)的C++Builder程序以供參考:<br>

          Private Sub Command1_Click() ' Visual Basic程序片段<br>

          Dim Ex As Object,Wb As Object, Sh1 As Object<br>

          Set Ex = CreateObject(&quot;Excel.Application&quot;)<br>

          Ex.WorkBooks.Open(&quot;c:\book1.xls&quot;)<br>

          Set Wb = Ex.Activeworkbook<br>

          Set Sh1 = Wb.ActiveSheet<br>

          Text1.Text = Sh1.Cells(1, 1).Value<br>

          For i = 1 To 10: For j = 1 To 10<br>

          Sh1.Cells(i, j).Value = i * 100 + j<br>

          Next j: Next i<br>

          Wb.save: Wb.Close: Ex.Quit<br>

          End Sub ' - - - - - -- - - - - - - - - - -<br>

          <br>

          #include &quot;Unit1.h&quot; // C++Builder程序片段<br>

          #include &quot;vcl\utilcls.h&quot; // util classes實(shí)用類說(shuō)明<br>

          // …省寫此處原一段代碼<br>

          // 請(qǐng)?jiān)诖颂幉迦肷厦嫣峒暗乃膫€(gè)宏定義語(yǔ)句<br>

          void __fastcall TForm1::Button1Click(TObject *Sender)<br>

          { Variant Ex,Wb,Sh1;<br>

          Ex=Variant::CreateObject(&quot;Excel.Application&quot;);<br>

          Ex.PG(&quot;WorkBooks&quot;).PR(&quot;Open&quot;,&quot;c:\\book1.xls&quot;);<br>

          Wb=Ex.PG(&quot;ActiveWorkBook&quot;); Sh1=Wb.PG(&quot;ActiveSheet&quot;);<br>

          Edit1-&gt;Text=Sh1.PG(&quot;Cells&quot;,1,1).PG(&quot;Value&quot;);<br>

          for (int i=1;i&lt;=10;i++)<br>

          for (int j=1;j&lt;=10;j++)<br>

          Sh1.PG(&quot;Cells&quot;,i,j).PS(&quot;Value&quot;,i*100+j);<br>

          Wb.PR(&quot;Save&quot;); Wb.PR(&quot;Close&quot;);<br>

          }<br>

          <br>

          ---- 使用這種方法的程序運(yùn)行時(shí),必須保證系統(tǒng)中同時(shí)有MS OFFICE;下面我們?cè)俳榻B另一種脫離MS OFFICE也能存取Excel表格的方法。<br>

          ---- 二.用ODBC數(shù)據(jù)庫(kù)技術(shù)存取Excel<br>

          <br>

          ---- ODBC就是開(kāi)放式數(shù)據(jù)庫(kù)鏈接標(biāo)準(zhǔn),不同種類的數(shù)據(jù)庫(kù)只需提供各自的ODBC 驅(qū)動(dòng)程序就可按相同的命令操縱,微軟同樣為Excel提供了ODBC驅(qū)動(dòng)程序,我們可在程序中象數(shù)據(jù)庫(kù)一樣存取Excel表格。定義好ODBC數(shù)據(jù)源后,實(shí)際試驗(yàn)中并沒(méi)有如想象的那樣簡(jiǎn)單,在控件Table的屬性TableName中總是檢索不到表名,同樣也沒(méi)有相關(guān)的資料可供查閱。通過(guò)對(duì)Excel的分析,終于發(fā)現(xiàn)了問(wèn)題的關(guān)鍵所在:ODBC的表名并不就是Excel的工作表名(如Sheet1),在Excel 

          表格中必須對(duì)要求操作的行列區(qū)域定義一個(gè)“名稱”作為數(shù)據(jù)庫(kù)的表名,該區(qū)域的首行各列必須是字段名(否則首行數(shù)據(jù)會(huì)當(dāng)成字段名),可以定義多個(gè)表名。具體操作步驟如下:<br>

          <br>

          ---- 1.在Excel上定義“表名”:<br>

          <br>

          ---- 運(yùn)行Excel程序,打開(kāi)或新建一表格,按下鼠標(biāo)左鍵選擇一片區(qū)域(起始行先填上字段名),再將鼠標(biāo)位置點(diǎn)到左上角的地址欄,輸入一表名如ABC,或者在菜單上選:“插入(I)”-“名稱(N)”-“定義(D)”,再輸入表名(若已定義, 

          可在此處刪除掉),存盤退出(假定文件名取為c:\Book.xls),若嫌字段名行多余,存盤前可隱藏掉;<br>

          <br>

          ---- 2.定義ODBC數(shù)據(jù)源:<br>

          <br>

          ---- 從Windows桌面“我的電腦&quot;進(jìn)入“控制面板”,雙擊“32位ODBC”圖標(biāo),運(yùn)行“用戶DSN”中的“添加(D)&quot;后選“Excel 

          Driver(*.xls)&quot;, 再點(diǎn)“完成”便彈出對(duì)話框,在“數(shù)據(jù)源名(N)&quot;右邊填一名稱,如:excel01,在“版本(V)&quot;上選“Excel97&quot;, 

          點(diǎn)中“選項(xiàng)”取消“只讀”,在“選定工作目錄”中,選定Excel文件名(本例 c:\Book1.xls),再點(diǎn)“確定”直至退出;<br>

          <br>

          ---- 3.設(shè)置Database控件避免登錄檢查:<br>

          <br>

          ---- 運(yùn)行C++Builder,在Form1中加上Data Access的三個(gè)控件:Database1、 DataSource1、Table1,加入Database1的目的是為了避免打開(kāi)數(shù)據(jù)庫(kù)時(shí)出現(xiàn)登錄框,為此雙擊此控件彈出一對(duì)話框,在Alias 

          name中選ODBC數(shù)據(jù)源名(本例為Excel01),在Name中填上一新的別名(本例取Excel02),再點(diǎn)“Defaults” 出現(xiàn)一批參數(shù)缺省值,最后取消Options中的兩項(xiàng)“Login 

          prompt&quot;與&quot;Keep inactive connect”,點(diǎn)OK退出;<br>

          <br>

          ---- 4.設(shè)置其它控件屬性:<br>

          <br>

          ---- 將Table1的屬性DatabaseName選為步驟3中的新別名Excel02,再將另一屬性TableName選為步驟1的表名(本例為ABC);將控件DataSource1的屬性 

          DataSet選為Table1;雙擊Form1,在FormCreate事件子程序內(nèi)加上一句 Table1- &gt;Open( );<br>

          <br>

          ---- 5.查看數(shù)據(jù)庫(kù)內(nèi)容:<br>

          <br>

          ---- 為了直接看到Excel數(shù)據(jù),在Form1中再加上Data Controls的控件DBGrid1 和DBNavigator1,將兩者的屬性DataSource都選為DataSource1,雙擊Table1 

          的屬性Active將值改為true,等待數(shù)秒就可看到DBGrid1中出現(xiàn)數(shù)據(jù),最后恢復(fù)Tabel1- &gt;Active為false;<br>

          <br>

          ---- 注意:程序編譯前,必須將剛打開(kāi)的表關(guān)閉,即:使Table1- &gt;Active為false, 否則程序運(yùn)行時(shí)報(bào)告出錯(cuò),因?yàn)镋xcel表總是被ODBC以“獨(dú)占”方式打開(kāi);<br>

          <br>

          ---- 我們使用的是C++ Builder 4.0專業(yè)版,電子表格為Excel 97</p>

    </td>

    </tr>

  </table>

 

</div>

</BODY></HTML>

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区在线| 久久久久国产一区二区三区四区 | 国产精品456| 老鸭窝一区二区久久精品| 视频一区二区国产| 欧美aⅴ一区二区三区视频| 婷婷成人激情在线网| 丝袜美腿亚洲一区| 男男gaygay亚洲| 精品制服美女丁香| 国产一区高清在线| 国产成人av网站| 波多野结衣欧美| 91玉足脚交白嫩脚丫在线播放| 波多野结衣一区二区三区 | 日韩精品中文字幕在线不卡尤物| 91精品国模一区二区三区| 欧美一区二区三区不卡| 精品国产三级电影在线观看| 久久精品男人天堂av| 日韩一区欧美小说| 亚洲国产精品久久艾草纯爱| 日韩精品1区2区3区| 精品一区二区三区久久| 国产69精品久久777的优势| 93久久精品日日躁夜夜躁欧美| 在线视频一区二区三区| 欧美一区二视频| 久久久国产精品不卡| 亚洲人快播电影网| 日韩高清在线不卡| 懂色av一区二区三区免费看| 91女厕偷拍女厕偷拍高清| 欧美久久一二三四区| 久久精子c满五个校花| 亚洲图片你懂的| 秋霞午夜av一区二区三区| 国产精品 日产精品 欧美精品| 色哟哟精品一区| 91精品国产色综合久久不卡电影| 国产欧美一区二区精品仙草咪 | 久久99精品国产麻豆婷婷洗澡| 国产91精品久久久久久久网曝门| 在线视频中文字幕一区二区| 精品捆绑美女sm三区| 中文字幕一区二区不卡 | 日本韩国精品在线| 日韩精品专区在线影院观看| 亚洲三级在线免费| 卡一卡二国产精品 | 精品视频在线免费| 久久日韩粉嫩一区二区三区 | 懂色av一区二区三区蜜臀| 欧美亚洲禁片免费| 欧美激情综合五月色丁香小说| 亚洲一二三四在线观看| 丁香婷婷综合五月| 欧美一级午夜免费电影| 亚洲天堂av老司机| 紧缚捆绑精品一区二区| 欧美日韩一卡二卡三卡| 亚洲欧洲性图库| 精品写真视频在线观看| 欧美日韩国产三级| 亚洲欧洲日产国码二区| 国内精品写真在线观看| 51午夜精品国产| 亚洲免费资源在线播放| 国产成人av一区二区三区在线| 日韩一区二区在线观看视频| 亚洲精品国产精华液| 成人性色生活片| 2020国产成人综合网| 婷婷综合久久一区二区三区| 色综合色综合色综合色综合色综合| 久久久精品蜜桃| 麻豆中文一区二区| 欧美丰满高潮xxxx喷水动漫| 伊人婷婷欧美激情| 91亚洲永久精品| 国产女主播视频一区二区| 久久精品久久精品| 69av一区二区三区| 亚洲一区二区三区视频在线播放 | 色先锋aa成人| 中文字幕一区二区三区乱码在线 | 日本道精品一区二区三区 | 国产成人免费xxxxxxxx| 欧美电影免费观看高清完整版在 | 91精品一区二区三区久久久久久 | 亚洲免费毛片网站| 成人一区二区三区视频在线观看| 久久影音资源网| 另类小说色综合网站| 欧美喷潮久久久xxxxx| 亚洲一卡二卡三卡四卡| 欧美性xxxxx极品少妇| 亚洲综合久久久| 日本高清不卡aⅴ免费网站| 亚洲欧美综合网| 97久久精品人人爽人人爽蜜臀| **欧美大码日韩| 色综合久久久久久久久久久| 亚洲精品免费在线播放| 在线观看91精品国产入口| 亚洲老妇xxxxxx| 欧美影院一区二区三区| 亚洲国产精品自拍| 欧美三级电影在线观看| 天天免费综合色| 日韩小视频在线观看专区| 国产真实乱偷精品视频免| 久久综合色播五月| 国产成人综合自拍| 亚洲欧洲无码一区二区三区| 91在线观看污| 一区二区三区小说| 欧美日本韩国一区| 免费在线看成人av| 国产亚洲一区二区在线观看| 成人黄色国产精品网站大全在线免费观看 | 欧美精品久久99久久在免费线| 午夜伊人狠狠久久| 日韩视频免费观看高清完整版 | 91麻豆免费视频| 五月综合激情网| 欧美sm极限捆绑bd| 国产成人综合视频| 亚洲欧美日韩中文字幕一区二区三区| 在线日韩一区二区| 麻豆国产精品一区二区三区| 国产欧美在线观看一区| 在线看日本不卡| 麻豆国产精品一区二区三区| 久久精品人人爽人人爽| 色婷婷亚洲精品| 免费成人性网站| 中文字幕成人在线观看| 欧美日韩精品高清| 国产精品综合一区二区三区| 亚洲蜜桃精久久久久久久| 91精品国产综合久久久久久| 国产精品亚洲综合一区在线观看| 亚洲蜜臀av乱码久久精品| 欧美xxx久久| 91在线观看地址| 久久99精品久久久久婷婷| 国产精品电影一区二区三区| 91精品国产手机| 99riav久久精品riav| 美美哒免费高清在线观看视频一区二区 | 91精品午夜视频| 成人综合婷婷国产精品久久免费| 亚洲午夜免费电影| 国产色一区二区| 欧美女孩性生活视频| 成人黄色av电影| 久久精品国产99| 亚洲综合色自拍一区| 2024国产精品视频| 欧美日韩aaa| 99精品国产91久久久久久| 美女免费视频一区二区| 亚洲视频你懂的| 久久精品视频网| 欧美一区二区国产| 色综合久久中文综合久久牛| 国产精品中文欧美| 日韩中文字幕一区二区三区| 亚洲视频在线一区二区| 26uuu欧美| 91精品国产高清一区二区三区蜜臀| 99re在线精品| 国产精品18久久久久久久久久久久| 亚洲成av人片观看| 最新不卡av在线| 国产喂奶挤奶一区二区三区| 欧美一区二区视频在线观看| 91精品办公室少妇高潮对白| 丁香五精品蜜臀久久久久99网站 | 91国偷自产一区二区开放时间| 国产福利不卡视频| 久久国产尿小便嘘嘘| 亚洲国产另类av| 亚洲免费观看视频| 国产精品福利一区二区三区| 精品久久久久久久久久久久包黑料 | 精品欧美一区二区久久 | 亚洲日本成人在线观看| 国产日韩欧美高清在线| 欧美tickling挠脚心丨vk| 精品日韩99亚洲| 欧美一区二区精品在线| 欧美日韩高清在线播放| 欧美又粗又大又爽| 一本色道久久综合亚洲91| 99这里都是精品| 成人激情文学综合网| 国产成人aaa| 成人中文字幕电影|