QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 57632|回复: 2
打印 上一主题 下一主题

c++builder如何和excel交换数据?

[复制链接]
字体大小: 正常 放大
韩冰        

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
0 D9 d% I* S4 X$ C" a- J<>  </P>
$ M% c- }1 }. _# t<>这是从网上下载的: </P>" R( _7 j  q$ k" r" g% X
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
& i! d& J4 `5 I6 r7 J5 ~<>  </P>
& f( O3 m0 u# z" \<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
7 K# s# C: ]; v& [; t7 ?# H& u# |<>  </P>6 y* `4 K6 a' C$ i6 P6 O
<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>
2 R4 }9 e- k) S7 p8 D# [<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
, D: G3 l- q" A6 f( a/ Q: n<>  </P>- z& ^8 U+ ~" [/ d) X. V9 [: I5 f
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>
; x6 D% ?+ }& L& @* K1 T<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>1 }, G: C* o6 h
<>  </P>
0 K4 A- K5 d; W$ w<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
5 B3 d/ c. v: |# d: y" b) C5 n2 j<>  </P>
  C. i( l' |5 }( {<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>& y  W6 o3 V; }  U# U8 C# u
<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
+ L3 ]6 `8 I6 T% I0 \<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>  P9 o# ?6 L* M/ S! R* a; E
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>* t: j9 Q% w# F/ p( m. M
<>  </P>
, t$ i8 z0 l  E<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
( r$ O% d: z  ^5 a7 o9 e8 j4 ~3 I2 r<>  </P># P9 F! `; l' w& w% g
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>- u0 G. ~$ ^, v; D8 [# L2 {! T; f
<>  </P>
0 |1 _# E/ q3 e! d5 _- \<>C++ Builder操纵Excel的具体方法。 </P>4 W# _/ \% _# j$ f) P; ^' G
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>* D4 ?2 H6 E. d% O) \
<>  </P>
- d) e' U+ e! s<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>
4 `8 r* p, T2 T7 q% D) ^* T<>  </P>
9 k- }$ x- G* f$ O* r$ f<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>5 Z- l6 t$ G/ @
<P>  </P>3 X, Z# f+ B2 R$ {
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
) F5 V8 H3 y, M' n1 w* Q<P>Button1Click()函数中加入如下代码: </P>3 j- A9 ^& A' J. Y2 P6 x& C% W
<P>   Variant ex,newxls; </P>
, o9 b6 o/ c$ n! \2 e/ y; R<P>   int i,j=1; </P>0 V. Z. u5 L- A2 H7 u- x- ~9 q
<P>try </P>3 g0 q2 ~3 y1 G1 B6 F9 U
<P>{ </P>: s) B% D6 o5 Y4 w; M1 M
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
+ [' a' J8 Y* N<P>} </P>
. L* O' `5 ]* A, i! z! [0 S* F: V<P>catch(...) </P>& D& q% `! O7 w
<P>{ </P>* J; y( b4 M; |; N' A" \
<P>ShowMessage(″无法启动Excel″); </P>
9 U1 x# S7 A: z5 t% c2 y' n  L<P>} </P>
5 E% a! R& l0 L1 x. V, E1 K9 m<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>- H7 s+ }% H$ M/ {9 n! h
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>
* J7 y. o9 k4 o, c& A<P>  </P>
$ K, N) x) D2 a# @+ [4 ~<P>Table1-〉Active=true;   </P>3 h7 j4 `  P, t
<P>  //打开数据库 </P>* S4 Q" u8 v9 u2 q3 L5 G
<P>Table1-〉First(); </P>
7 P; h) ?& r8 c4 n/ b<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>: I! C/ c+ Z8 D6 x
<P>  //将字段名写到工作薄的第一行 </P>6 ~6 e/ t9 A  @: l
<P>{ </P>. }0 c2 F( k5 o+ [4 R0 _
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>& R# K1 c- s! C/ u% E
<P>  </P>! |# C2 B* O. ]
<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>. P' G. G2 s7 P* T4 ^+ G3 }
<P>} </P>2 q: `+ \; x$ w5 M
<P>while(!Table1-〉Eof) </P>5 B( z& {% J6 G% `! z; G
<P>  //将数据库中的记录依次写到工作薄中 </P>' k) i* G9 V) w
<P>{ </P>7 G* i7 ]( l/ k/ D1 O9 {
<P>j=j+1; </P>
6 ?+ [, Y. ?4 \$ J+ F% e8 @<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
; U% I* `% u3 `2 s2 l) i' i* C<P>{ </P>$ h1 w9 n/ Q' Y% V
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
& d" g) K! p) b3 S5 r<P>(i+1), </P>2 \3 C3 \5 }  e3 Y
<P>  (Variant)Table1-〉Fields-〉AsString); </P>3 {! X. q+ H: B& Y0 r$ m" h
<P>} </P>
: @- Z+ U( E* C9 R<P>Table1-〉Next(); </P>
; R% M" M' ?5 F! S3 \( J) X% g6 I0 O! N<P>} </P>; |5 Z( d  F9 r3 A
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
/ m* ~+ S+ M" K; k6 i<P>  //保存工作薄,filename是工作薄的全文件名 </P>; P: m) S, [# Z& l
<P>ex.OleFunction(″Quit″); </P>
8 g% J; a$ u" d. G. K. x$ S4 D<P>  //退出Excel,释放OLE对象 </P># `: g( R. t3 H9 \, y4 ~3 _+ r
<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>' h0 O) A6 g5 X* `
<P>include ″ComObj.hpp″。 </P>2 W. A4 j& x3 b& O! X7 H+ q( ?- m4 W
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
2 D7 }! J  l+ [& P<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
" K( ^+ X, \- H<P>  以上代码在Windows 98操作系统、C++ Builder 3.0下调试运行通过。 </P>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
liunengwu 实名认证       

0

主题

3

听众

147

积分

升级  23.5%

该用户从未签到

自我介绍
我是一个数模爱好者,希望在数模中获奖!
回复

使用道具 举报

3#
无效楼层,该帖已经被删除
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-6-14 11:59 , Processed in 0.360930 second(s), 63 queries .

回顶部