- 在线时间
- 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>. G7 O r9 n" O z- }
< > </P>
t* _' u# V9 @! F2 e% I< >这是从网上下载的: </P>; U% c# x- _+ I( k; Z+ M0 ^
< >Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
4 D2 P7 r) D3 V$ V q/ U3 U, c4 q< > </P>
: A% W2 _5 w' O: |, U6 ]< >据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
0 D+ L2 q6 J# Z< > </P>3 q: Q8 |/ d- W# q7 I# f
< >加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>9 J' l5 Y! K/ h0 \
< > C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
0 z, `! l; n9 z5 L0 y< > </P>
' k; k* w( `, W- H9 r2 U% n: g7 F7 z< >使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>
4 ^+ H6 V& T8 {$ K7 s< > 在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>& l% k q' ]- q5 R" q
< > </P>% p6 w: x8 I: Q
< >对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>! x3 X0 c3 K7 i9 V
< > </P>, P1 i& _- {8 x" s7 D; r
< >建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
4 |+ d3 N1 ~" z1 ^6 n4 o, M< >OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>& k' U+ A8 U+ Q4 z6 {/ Q8 I; `
< >[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P> c, L- A$ R$ g
< > C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
! n7 G. ?5 N2 U# |# N w* N* t& b< > </P>& N+ ]( H2 A& U" W! m6 B
< >Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
; X5 |& s) X8 M7 S' H< > </P>6 t) F7 T6 s5 B8 }- ~
< >中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>
; Y& |# p+ ]! ~ e6 P< > </P>
0 I1 f* f, }8 L< >C++ Builder操纵Excel的具体方法。 </P>
- H" \/ F: R. w* }+ ^< > 首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
\8 i5 y1 N, N5 ^+ c< > </P>% q. h9 H' Q9 a% g2 Y
< >然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>- E2 g2 R. `( R' b* A7 `7 i; o
< > </P>
, ^' i. u( ^0 I, ]4 T- Y# B< >为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P># z, U( o2 G* {$ i
<P> </P>8 {, m0 V& s( Q; X; n
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
2 K" u4 E# L4 I6 Z<P>Button1Click()函数中加入如下代码: </P>
% b @ o. @/ G8 ?8 \) \<P> Variant ex,newxls; </P>! [% u! D. G6 q- |! x
<P> int i,j=1; </P>. t, E( s, Y7 h8 l6 ~, p, {# X
<P>try </P>
& P. J* D8 R: p9 x<P>{ </P>" \0 d8 V: r; B8 @1 S P
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>0 p! S8 ~0 v- g+ v* h, r' Y
<P>} </P>
! G) i- x4 E2 I$ D1 ]: U<P>catch(...) </P>! k5 H* V' }- \
<P>{ </P>
" _* S& U, s+ {! E; H: X8 h<P>ShowMessage(″无法启动Excel″); </P>
9 N5 E( Z8 | u! W! }<P>} </P>% O2 t8 U% ?" O1 f/ F/ X7 v
<P> ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>9 [6 a: H0 d) m- [) W8 x- b
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>' E5 A4 _8 B# i9 c7 F$ f
<P> </P>3 c3 s$ v+ T! O. l' e
<P>Table1-〉Active=true; </P>
3 {/ T/ u7 l+ [) d7 [6 `<P> //打开数据库 </P>
! Z: [- K5 u! p6 W4 R9 e# }<P>Table1-〉First(); </P>0 ~+ [+ e3 c, ?4 b3 o3 y9 v# U
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>3 J5 H! ]+ V$ Z3 X- x: {6 K5 _" ?7 ^
<P> //将字段名写到工作薄的第一行 </P>1 R- Q7 M( B9 H2 N. |% C6 ?
<P>{ </P>
3 W4 T0 @: K; y9 G<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>- b+ y1 x# W( _1 t6 a1 `7 T
<P> </P>
3 y( V% _$ o: p7 o* b<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>
- z" J; a( s5 W6 E2 W<P>} </P>" p: g1 `0 s% F8 B! Y
<P>while(!Table1-〉Eof) </P>0 u2 H' I( i7 V% v0 H3 r2 Z
<P> //将数据库中的记录依次写到工作薄中 </P>2 R- B- j8 q: _, ?4 A
<P>{ </P>* `. J& D$ M& f3 P6 w: |
<P>j=j+1; </P>
% E# h- V, S. W. B<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
! V! z' z& ]4 z% o<P>{ </P>
& x3 B/ ~5 F# t2 J; I1 i- T<P> (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>! ~" e4 u- M; \
<P>(i+1), </P>
. m8 b& z K/ Z: U<P> (Variant)Table1-〉Fields-〉AsString); </P>6 i5 @1 |! y3 Q# V- X
<P>} </P>% B% _4 u' _5 @' H+ Q& p
<P>Table1-〉Next(); </P>
/ e8 r( P) L" F2 z- M7 A4 s7 p<P>} </P>
2 H W" E( A( E) b5 g& x7 i7 _<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>- a; a6 `! ` J% O; Y$ @
<P> //保存工作薄,filename是工作薄的全文件名 </P>& m4 Q& H: I& G: D" G1 o B7 o
<P>ex.OleFunction(″Quit″); </P>" R+ ?& M* m& A3 p- t
<P> //退出Excel,释放OLE对象 </P>$ w0 ]9 d2 t4 ^8 j, v5 Q7 W
<P> 注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
! U! _+ U3 q$ B- J<P>include ″ComObj.hpp″。 </P>% N; {+ S; a% _/ b/ Y+ d( H5 Q
<P> 运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
9 R$ j J4 y* k! |: k- S<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>4 g% \; B$ s7 _, x0 h2 V d2 w
<P> 以上代码在Windows 98操作系统、C++ Builder 3.0下调试运行通过。 </P> |
zan
|