QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
#
发表于 2005-1-26 01:22 |只看该作者 |正序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>* [# v% |7 r$ ^; p
<>  </P>7 W' c' p+ x3 u5 A3 M
<>这是从网上下载的: </P>
; p/ b" }. i: N' E! a<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
) P- p" B) ^2 i0 U( [# P<>  </P>
. p; y" O. a+ X5 }4 r) c+ H<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
: H  H+ ?9 m% U<>  </P>0 ?3 X; Z) K3 Y* F; P; X
<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>% S. @, Q( O1 O: Z4 Z
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>, N* D+ N! E9 ~( q: r' o6 x
<>  </P>" {6 u' |; ^6 E8 d
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>6 M  A  h) Y; ?
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>+ I" a& H, M4 a* N4 ~) z
<>  </P>; J* e; D' X8 Y% R
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>! U# q0 J5 k1 X/ @: s! Q  @3 n
<>  </P>- C' e2 P4 J+ v
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
! \3 ~! C% \8 w4 X<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>2 a2 R" w( `" p) z: d. V2 y
<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>" m6 H  r) Z' E
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
, ~1 m8 D! `+ L: E<>  </P>
: ^, B7 k) A( c" _9 A$ t$ [8 I2 I<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>/ P" |) m" ]  c* K' Z) V1 R: G
<>  </P>, K+ k: W% ~. E, ]" t: D9 U
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>8 S; {. \  ?- T( }; a! O0 U- w
<>  </P>9 X2 E5 i% h" P0 P" g+ y
<>C++ Builder操纵Excel的具体方法。 </P>) v& x' t. c3 _5 v7 S
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
  i$ e6 ^0 A( j<>  </P>
5 ?4 l+ e# l3 U% {$ W# U<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>. T- I& {2 N& ?1 P5 h
<>  </P>
+ ?+ h) I$ }# Q% [<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
" @8 y; ?9 x, i* N) x3 ^<P>  </P>7 z/ F9 p! D% t+ |# Q- h
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
6 o  k+ ]- Z$ j5 O7 }, H4 X<P>Button1Click()函数中加入如下代码: </P>4 o+ G1 l  w9 j  P8 {" J' r
<P>   Variant ex,newxls; </P>
( R' y! ~$ ]* g5 [<P>   int i,j=1; </P>. w& u5 }% X  o
<P>try </P>
% y5 [; i/ Y1 Y3 m<P>{ </P>4 v; X" Q) U- S/ A2 K" o
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>- U- j/ _8 _$ T
<P>} </P>
- s3 Q+ E; P, o& n% k/ Y( E1 ?<P>catch(...) </P>% q5 a5 ^) ?% n& O( k- m
<P>{ </P>
/ T3 j- f+ F3 C% ~$ k<P>ShowMessage(″无法启动Excel″); </P>
' L% ?- @1 _) G, n/ e# A8 m<P>} </P>8 j4 t2 b6 ?+ B% i) l6 B' B- n( q
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
3 Z  j' o3 `. y. D! E1 D<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>, E) y7 r1 p! ~" r
<P>  </P>0 y& i0 a# J9 b  T; t( t
<P>Table1-〉Active=true;   </P>8 ]& G' @; N2 P+ Q" Z7 H7 D
<P>  //打开数据库 </P>. f; L6 w% k( i3 T! z
<P>Table1-〉First(); </P>
0 X) H/ {5 `* _; k<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
. l( Q' b( a; u' W: P* p7 G<P>  //将字段名写到工作薄的第一行 </P>
  u9 B5 v1 b, `- G" U" m<P>{ </P># ~/ f" s4 w3 x
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>9 Z3 t" V( y# d1 s
<P>  </P>
- |" F& @* r7 Z6 c6 \$ K<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>0 p) j  C% c& `% F
<P>} </P>
7 W- g+ H7 y. b  G! Z" w* q2 A<P>while(!Table1-〉Eof) </P>  e# T# r0 ^0 `1 R2 }; T
<P>  //将数据库中的记录依次写到工作薄中 </P>
0 C- o: {7 R) g  l<P>{ </P>
3 _  A/ ]$ N0 k3 d; V<P>j=j+1; </P># Q/ |: Q7 ^& p6 B% R
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>/ D5 m7 G9 v* F& P1 {: l0 X
<P>{ </P>
7 w  ]$ h' N# A4 R8 E, K) H" C+ g<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>; G0 U5 c7 K9 y) z& V) s& w  k
<P>(i+1), </P>
+ a' L: O1 U# ]! L1 o( F; T+ ], i<P>  (Variant)Table1-〉Fields-〉AsString); </P>
- ~- l, R5 P0 M' ]5 U2 I<P>} </P>
7 F; X4 S7 D0 z<P>Table1-〉Next(); </P>
5 E: V( f# u+ f; c# Q<P>} </P>1 T' i7 ~1 Z  s; n9 L! r) o
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
3 f" y" U5 ]/ S, o! t- ?8 q<P>  //保存工作薄,filename是工作薄的全文件名 </P>
! z- H2 W( U# U2 \<P>ex.OleFunction(″Quit″); </P>. i' H1 N. v. ]7 B
<P>  //退出Excel,释放OLE对象 </P>
8 M# H5 L* ]9 _( L0 T$ Z% g<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>) T3 y5 O% B* U* q2 p
<P>include ″ComObj.hpp″。 </P>
7 J& W+ O) U# [- F# L, w0 Q2 s* R4 z<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>, X+ A1 c* ]$ j" i/ j2 C, Z' L5 J- f
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
8 w) F* q; L0 [# }<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, 2026-4-19 18:54 , Processed in 0.477947 second(s), 56 queries .

回顶部