- 在线时间
- 0 小时
- 最后登录
- 2007-9-23
- 注册时间
- 2004-9-10
- 听众数
- 3
- 收听数
- 0
- 能力
- 0 分
- 体力
- 9975 点
- 威望
- 7 点
- 阅读权限
- 150
- 积分
- 4048
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1893
- 主题
- 823
- 精华
- 2
- 分享
- 0
- 好友
- 0

我的地盘我做主
该用户从未签到
 |
< >c++builder如何和excel交换数据?</P>
1 t3 w- ^1 R: g3 I( T1 l< > </P>
& i# N/ i* u: @1 N< >这是从网上下载的: </P>" r4 E. I/ ^$ b( |$ a& Z4 Y
< >Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
f9 w2 |8 ]+ a+ D, B; Y< > </P>
1 ^: Z0 x" M# f% Q& T8 m< >据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>& I, N( J4 q' ~+ k
< > </P>
8 h; o' @5 v" I2 d! E9 T5 b" {< >加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>+ w* A0 v4 I# |
< > C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
u5 v9 K$ L: ~9 p< > </P>
% B5 z+ z% R8 s1 n3 m# e7 Q% L< >使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>7 W7 k) W) E/ K/ t, b
< > 在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>
' B. D" q6 M* A8 r< > </P>4 V3 o" i& \# T7 G+ ~# _* x
< >对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
# U+ m \' A: [# T9 B< > </P>2 M1 l# V' N" z7 ^3 j+ f2 _9 k
< >建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P># x2 t) M; M0 p5 i% i* Z' K
< >OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>- r% Q: A0 _- R6 ?
< >[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
) y) H8 B+ B/ H6 U( o< > C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
: C9 }0 k: h; P< > </P>
/ ^* A5 H& W6 H) d/ C< >Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
. v4 [4 j7 P3 i/ U< > </P>( e) S( {% s' S0 f. e- L
< >中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>: V; r5 U& O3 k" n9 r
< > </P>4 R( ^. G- ?" s% M( ]& F W& g9 `
< >C++ Builder操纵Excel的具体方法。 </P>) T( \0 n3 S) \, v& B( O
< > 首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
! g" b* X' o! m9 l8 H< > </P>
" _! C I0 d( j) u$ k; g< >然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>
5 B0 V4 _7 C* `1 V2 T0 @. c( ?< > </P>& c+ Q. {' E0 ]# I w
< >为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>' C! H+ K, @; z7 V P
<P> </P># B$ L3 Z0 d) `, ^( o- o- {
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P> y1 k- W7 B: C8 |' Y/ ]
<P>Button1Click()函数中加入如下代码: </P>
i* N' S0 X! V" @# v- G6 v<P> Variant ex,newxls; </P>
% H! O* y) _4 K- X0 m# M<P> int i,j=1; </P>- f# o a8 X. D1 _4 o) _1 r: S* Z
<P>try </P>5 }+ m. m7 `/ S( A! H
<P>{ </P>; {2 ?/ n: F. E8 c& [2 n. _2 m6 _$ \
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
6 l- u$ e5 m: ~/ }( Z<P>} </P>
) T- Z: }- M V7 ]<P>catch(...) </P>
" x$ J* Z' l+ Q0 I) h<P>{ </P>
0 y- K5 h* y, h- `2 e4 ^ [<P>ShowMessage(″无法启动Excel″); </P>
$ `8 K0 D& t% d% z, h6 M<P>} </P>! x. Y& l5 ?: E5 g
<P> ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
1 _1 P; ]7 ^0 ~% S$ D- S<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>7 a* e$ `! `, }0 Z# b
<P> </P>- ]( _6 ~& \3 q F. }. ~
<P>Table1-〉Active=true; </P>% N- d: j$ X! k+ W/ o. t5 }6 W
<P> //打开数据库 </P>
- O) c H: s, h3 n1 D<P>Table1-〉First(); </P>( @6 c2 X2 `2 w
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
! Q+ w. p2 Y# ?1 @0 k3 o! s' o! b<P> //将字段名写到工作薄的第一行 </P>* b3 G" R' Z9 R
<P>{ </P>
5 { H+ ?) x& |% {# ~/ ^<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>4 R* p: }. T! ?/ i: f H
<P> </P>
( t" p- b" l0 n- ?% U<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>7 m6 c+ N( b! r5 O
<P>} </P>
% ^0 d# I* k$ D' h% y$ } S<P>while(!Table1-〉Eof) </P>
& {: k8 ~$ t4 z c& L<P> //将数据库中的记录依次写到工作薄中 </P>( y% ^# U S& b4 ]4 e! J v
<P>{ </P>% T: |7 i8 a" f% A9 M
<P>j=j+1; </P>% d _# g, L' r$ r% y9 k' S
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
4 g d! p' ^7 x<P>{ </P>
# t9 f j- M5 r2 ^: ~ g4 ~6 \<P> (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>( f( G+ b9 p3 t0 Q: [
<P>(i+1), </P>
' G9 P1 b* @1 K. a0 t# }<P> (Variant)Table1-〉Fields-〉AsString); </P>
- |# C* x0 s# h F; i4 O) C<P>} </P>3 O$ v; v/ ?' V
<P>Table1-〉Next(); </P>
0 `. _7 L* P9 z- t" r<P>} </P>
% A3 r/ R2 U+ {! P: o: B* Y& D1 p<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
) a, ^ X% l. Y7 m$ S& V<P> //保存工作薄,filename是工作薄的全文件名 </P>8 ]( y0 ]: q* b' |4 i
<P>ex.OleFunction(″Quit″); </P>3 i3 W/ [( \7 L% Z
<P> //退出Excel,释放OLE对象 </P>
. \( D7 z/ `: D9 P$ K<P> 注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
5 k* }, i' y! C<P>include ″ComObj.hpp″。 </P>2 ?& L5 J1 d. P' a
<P> 运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>% Z' P ^" D. G
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>% n( @: S% _1 M3 J& H
<P> 以上代码在Windows 98操作系统、C++ Builder 3.0下调试运行通过。 </P> |
zan
|