QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>0 b+ v$ t) u- }! l& Z
<>  </P>
. S- {% W+ t# F) i/ x2 Z4 k<>这是从网上下载的: </P>
: e2 H; B) r  e" a<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>5 l2 Z- e( O) \  \% U, D
<>  </P>
/ f' E+ F# m2 O( g, b/ e" `0 b<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
+ Y- G$ |; T( B1 `; r; W<>  </P>
% [5 o( Y3 `2 b<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>& m. S' R6 q! Y/ c' F+ W
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
, T  g/ ~  f" b# c<>  </P>
( _: H; X9 P" ?- k6 K- _<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>0 T+ y0 F3 u$ o7 s
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>7 L5 d4 ~; ~7 o  ^% D& S
<>  </P>/ v! S1 w! |$ n! h$ I
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
& w/ O  b8 o$ H7 P! j<>  </P>  L2 e  j; c) u) C
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
+ E1 r4 r* a& n  W<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
0 y' U/ r& Z8 C<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
9 b+ c4 h8 m% J" j. H<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>; [& {7 J4 d5 O. J+ h
<>  </P>  S; C4 r# X3 l
<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
0 _, F: g4 h# z+ L2 A7 i/ x<>  </P>
: a/ y2 N/ x3 P<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>) k4 v+ h  s# Z/ j/ }* s
<>  </P>( H7 u& n( x8 Y3 }
<>C++ Builder操纵Excel的具体方法。 </P>( u6 E) S8 y, x
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>! j' A8 w2 J" V, H
<>  </P>
$ D" O! Z9 w# v- z/ Q% X2 w<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>2 @" a# h: l  l3 O& P3 m) [9 v
<>  </P>/ O  _- A2 }/ |$ D. O3 f
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>) w3 D4 J7 ~6 @+ z" x) N7 ?* G# Q% N
<P>  </P>
* i* z1 U) P, V3 h& ?( I6 U<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
/ C6 L/ n* B- p6 ?% o! E: E( ]<P>Button1Click()函数中加入如下代码: </P>" i6 H, J( ~! L( z0 E1 L
<P>   Variant ex,newxls; </P>
3 H4 i8 G2 S3 V5 [: K2 K<P>   int i,j=1; </P>8 d! h! o0 X3 A# f* M4 }8 |9 P
<P>try </P>' Z# E$ _1 s! o! [3 ]7 G
<P>{ </P>
0 X, |' K. t: `<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
8 v1 r" V  `8 A) ?<P>} </P>
3 `+ l/ A$ [3 V9 _8 m" q<P>catch(...) </P>" R% i. q) n. O- i. Q- O  I
<P>{ </P>5 u+ Y0 i3 w' F6 z% H, P1 m, w
<P>ShowMessage(″无法启动Excel″); </P>3 h8 H. |2 N3 Q! }
<P>} </P>4 l9 d& h+ N/ U+ ?
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
4 ?8 v4 M/ |9 l- E; O<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>3 |  ?% N/ ~7 F; V
<P>  </P>5 {( Q! N: n& J
<P>Table1-〉Active=true;   </P>" ?: b- v; t  S' V( F6 J
<P>  //打开数据库 </P>& U1 D: B/ x" o6 e5 z
<P>Table1-〉First(); </P>
; i& B4 {( M7 @/ k, m<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>( D  \7 o* H- d' R+ T$ S0 x
<P>  //将字段名写到工作薄的第一行 </P>( ~2 g3 q4 ]% @1 o& G
<P>{ </P>5 |) M! W4 u& x  {' c: I
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>- z2 l3 h( _  l( X3 M5 j5 p
<P>  </P>) R( E1 x8 i2 q2 B+ x* q
<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>/ W& i: W: ], q- A1 e
<P>} </P>9 O7 b2 [! t. F; M, i! t: w
<P>while(!Table1-〉Eof) </P>
9 _0 S" W. h! _4 |<P>  //将数据库中的记录依次写到工作薄中 </P>
8 n% y3 o: q1 Y8 G% S" R<P>{ </P>0 n. ~* \4 a, w) A9 Y. s) r
<P>j=j+1; </P>
7 e, p- B2 ]1 v6 M" N8 b<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>  z7 a% \6 H+ P+ U+ g9 a
<P>{ </P>% l# n4 o& c7 S+ n7 Z8 K
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>$ }; F- |* }7 E* q& L
<P>(i+1), </P>
3 m2 E4 Y' H& f/ x  D' E<P>  (Variant)Table1-〉Fields-〉AsString); </P>
' L1 @' r4 @+ A. p! w2 q<P>} </P>
( J! |4 ]. W3 m, c* j4 M: r2 K<P>Table1-〉Next(); </P>
1 V; k- T- v8 B2 e& ^1 w<P>} </P>
3 l3 _7 R( v# U; S3 ?* Y0 |3 C' v: N  z<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
* F5 G6 N: _) {) T4 d' Y<P>  //保存工作薄,filename是工作薄的全文件名 </P>2 M- s; V/ P  i6 u: F( X# v* h
<P>ex.OleFunction(″Quit″); </P>
- J+ U( \( q1 G5 O  @% f<P>  //退出Excel,释放OLE对象 </P>
5 W0 V6 _3 I, C* y0 c: J' W<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
! B7 k3 h9 F$ n3 q# d% J<P>include ″ComObj.hpp″。 </P>  Q2 H& A1 r( x, h7 T& }' q
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P># q! c# w  D5 d# _% y
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>8 f( e+ F5 p; j) I& Y( X! X
<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-20 20:08 , Processed in 0.424193 second(s), 56 queries .

回顶部