- 在线时间
- 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>5 u. \( L2 O7 h5 Q9 }; {
< > </P>$ O( {1 O d1 p6 g
< >这是从网上下载的: </P>
m# S( [) G$ h7 k: M" b< >Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>% X* K, x0 t# p! o( d4 c4 m
< > </P>
$ ?5 ]4 g; g9 Z< >据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>$ k0 Q" a. O( s, D$ O ^$ R
< > </P>0 `; A: k3 {% A* g9 Y& o
< >加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>
4 |- [. l5 U0 D! R$ X( M< > C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>3 E) N4 k3 _! @7 h( X8 p
< > </P>
" j5 c+ y8 t2 Z9 \8 ~0 Y2 s< >使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>
, @% w2 E3 x, E0 i< > 在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>( Q7 b8 p+ {1 t0 q5 x. v& o* s
< > </P>
; K3 J" E( I4 T. C< >对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
; }0 K. U, h q9 g0 X6 Y< > </P>
6 Q) P' p4 S: R; C% P }' Z7 j, L: `< >建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>, g3 K3 U* Z( p; R& `7 O$ i
< >OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
2 k. v. F7 a M, r+ G. [< >[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>6 |6 i+ T1 d1 G$ o U
< > C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>+ D2 j( l- ^% a% ^) ]( e
< > </P>
% G% J. _: K) ]2 g$ S) W6 I< >Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>+ t" r' k# L" V
< > </P>
9 Y+ c- U$ j; M< >中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>8 f9 X6 S. |! Z8 L; |& F
< > </P>5 t2 E. O) i* T* V1 r0 Q6 M8 w9 i
< >C++ Builder操纵Excel的具体方法。 </P>" r9 ^; g* @ y8 z! q3 w
< > 首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>( ^2 _" e3 `8 [, b6 y
< > </P>
& G1 ~' s; O8 j$ p$ m< >然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>
9 H& @+ F) b& m% P# ^' V/ ?! u< > </P>
2 v7 t$ ^5 F& T5 M" T6 u< >为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>+ x) \6 J) j# ^: ~( Q6 F
<P> </P>
( R" D/ D2 C2 S2 f<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>. @' D8 x s# u8 j) n
<P>Button1Click()函数中加入如下代码: </P>
7 w1 ~) J. n1 p+ e- b<P> Variant ex,newxls; </P>/ l; ^+ B/ a7 W0 a8 K! f. j
<P> int i,j=1; </P>
) e9 H, P9 K/ y; D/ p' S7 b; H<P>try </P>
) n; n+ u$ {* M( O/ O8 }<P>{ </P>
b: \8 V4 j; [* b1 I. B<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
$ \4 z* ?8 B1 W! t# C- f1 B7 I3 S<P>} </P>1 G1 ?$ S3 D2 V' A, g
<P>catch(...) </P>
+ S% Z. u6 [3 `9 Y0 @' e. L7 q<P>{ </P>1 W2 D0 e+ L# K, }6 |+ H, M1 H# n
<P>ShowMessage(″无法启动Excel″); </P>
4 x; y3 ^" p+ H U1 R<P>} </P>2 X$ y1 `5 U' O
<P> ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>3 n" o. Y9 W) s! f
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>' N* g k1 r) x" N" q# `
<P> </P>
( K$ ]+ I* |7 Q<P>Table1-〉Active=true; </P>8 ]: U5 R I2 o7 u# Z, S
<P> //打开数据库 </P>2 U+ d5 ^, Z: O9 ^% F" e
<P>Table1-〉First(); </P>
$ o3 d/ K; x2 I, H& Q" ~ t<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
/ `( e' Q+ k! |/ z d+ I. J/ S" {<P> //将字段名写到工作薄的第一行 </P>
7 ~1 h, O k) a$ @# k' S2 F2 c) G<P>{ </P>! {$ y. r- r4 [6 }6 {- } k
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
, m4 z9 H `" V5 M<P> </P>
' J& U& w! d2 a4 A" m<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>
; \6 a! w" E5 v5 a! P<P>} </P>
1 q- _' [0 h: @& Z( |& u6 c: K) W<P>while(!Table1-〉Eof) </P>
: T# q& S0 A% L0 p3 J( f5 H<P> //将数据库中的记录依次写到工作薄中 </P>
, x; ~8 R* t$ i# X5 [<P>{ </P>; U) P; i+ K, G
<P>j=j+1; </P>) o T! W, ?7 w7 O
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
4 L9 @' Q( F) p7 y) G1 q8 M<P>{ </P>
$ ^6 [9 E( A( q/ i( ]* A) T<P> (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
8 _; G& y* C- _& }" s<P>(i+1), </P>
+ j9 V' L. U! U3 M3 O4 {<P> (Variant)Table1-〉Fields-〉AsString); </P>
) m$ [% M4 e! |4 S<P>} </P>' a1 {1 u+ O& ~3 ~6 I3 ?$ k
<P>Table1-〉Next(); </P>6 d6 X: K% T2 }7 T1 U8 W E
<P>} </P>, S/ B$ |; r' R: J3 F
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>9 ]; Z: Z: R; D+ b
<P> //保存工作薄,filename是工作薄的全文件名 </P>
1 d- z% u, t) s2 p9 } v: L<P>ex.OleFunction(″Quit″); </P>7 O$ a( Y8 M6 m/ t: ~. B4 n( M5 W
<P> //退出Excel,释放OLE对象 </P># K( z Y3 D) C( j" Q5 m
<P> 注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
0 v% T% b5 l l# r( y' t# c<P>include ″ComObj.hpp″。 </P>
3 v7 i) A4 K1 e& p f( N8 [! z<P> 运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>4 z7 v! L' L" U P# S
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
1 Y h7 p0 s- @* |, @ ] U' @<P> 以上代码在Windows 98操作系统、C++ Builder 3.0下调试运行通过。 </P> |
zan
|