QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
#
发表于 2005-1-26 01:22 |只看该作者 |正序浏览
|招呼Ta 关注Ta
<>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
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
liunengwu 实名认证       

0

主题

3

听众

147

积分

升级  23.5%

该用户从未签到

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

使用道具 举报

您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

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

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

蒙公网安备 15010502000194号

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

GMT+8, 2025-7-8 18:22 , Processed in 0.488820 second(s), 56 queries .

回顶部