QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>; M, A5 m. k! I# w% G
<>  </P>% A/ ^1 ~1 H( `/ a5 _% `  t
<>这是从网上下载的: </P>
0 o- Q% T/ P$ }' h6 y- V<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>4 ]7 S* A& C( N# v1 z+ k
<>  </P>
# N- {! S4 t% d5 K4 o! ^: Q<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
- i5 R% D1 q* ?* V( l<>  </P>
4 u6 d8 f  i6 s/ Y/ }9 S& f. r4 `" d<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>1 d+ _9 \# k, \2 N/ Y7 w
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
% F% m/ V" d! Y2 m0 q9 M: J0 I# b<>  </P>+ @7 J; @8 Q! L* E4 D; b
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>% E9 A( d+ S2 {7 s
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>+ T1 J% O6 t: A8 g* P( M
<>  </P>% i7 ?1 g5 C  a0 x' n( ~# A
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
' B1 f% R, @3 [<>  </P>8 w$ D5 H( o$ W; b, c
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>; y0 x% U6 i( n
<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
4 V4 s$ }7 T4 W1 ]1 ?3 ?7 T5 Y$ p; D<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>* Y& y$ S* b" r% R, T' s, c3 g9 N
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
+ Z1 S4 d+ E1 C9 E7 Q<>  </P>
" z% S& ~8 q' q# _<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
9 A; N2 l5 Q- k5 u& a4 N) t2 t<>  </P>2 O3 _. Y" Z9 X( N3 V7 }( K; r
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>
0 s6 X1 u# l9 L/ H& J5 i<>  </P>
. M( C3 r1 j6 v) |2 O, Y& }<>C++ Builder操纵Excel的具体方法。 </P>, _2 p3 n& O5 @1 U
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>! ~. d/ @" }# ?( P1 b3 b
<>  </P>' o  |( I+ f2 k: F) [
<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>; P+ z1 ?# {$ _* m* i7 d% Y. u1 h
<>  </P>
& i0 S1 J+ X1 E& e* }$ X1 Z<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>, B, A- V$ T4 y& h* I
<P>  </P>$ v  Y4 A; V6 N8 w. ?
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
2 {, {; x9 F/ k! M<P>Button1Click()函数中加入如下代码: </P>) Z+ j% M9 U4 N. }( M: t
<P>   Variant ex,newxls; </P>" W7 m, _0 ], p3 w" F
<P>   int i,j=1; </P>1 |6 t2 P9 _" A* d
<P>try </P>3 l  y: S1 ~3 Y0 K  w3 c8 X
<P>{ </P>1 z: C( a) B! P# k* K
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>3 Z" M) |0 [7 X. ~1 v
<P>} </P>
- b5 g, P- W& u4 z0 [<P>catch(...) </P>
6 A+ ], p- v5 h<P>{ </P>
4 N  i/ L" H( R) ^& w<P>ShowMessage(″无法启动Excel″); </P>" J  g, K/ Q# s5 e7 C
<P>} </P>
# \7 I/ y* b- j1 n<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
$ u) P0 k0 J% k0 x: |3 U" k<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>% P8 u3 P$ D% F/ R9 [2 a
<P>  </P>
  \4 c4 E# J; v4 ^<P>Table1-〉Active=true;   </P>
# l/ R( F5 @6 f  P' o3 \<P>  //打开数据库 </P>
. z' F9 r, T/ \! O% u<P>Table1-〉First(); </P>
- q. V# W7 v9 d- F4 b7 C: X# I<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
4 s+ F$ Z  T2 ]4 t6 a; K4 F8 T<P>  //将字段名写到工作薄的第一行 </P>
- ~( v5 u9 J$ c% o4 B<P>{ </P>0 ^4 N, o3 t& x- F
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
6 }6 Y1 q. z+ Z5 ?3 }! e4 Z<P>  </P>
$ v  W$ c7 |. u# n3 [  T<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>
- }% G6 u7 ]5 v1 e% o* w. [<P>} </P>
& K8 n) n, \5 H; b  L2 i6 X<P>while(!Table1-〉Eof) </P>
. N  X/ @% q& X. Z4 Y: r; S% z<P>  //将数据库中的记录依次写到工作薄中 </P>
8 Y: U- f8 u- s<P>{ </P>
; ^# P) D, `& |+ x<P>j=j+1; </P>
: n  y( }+ a" \<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>! m' ^, S7 n0 J$ R
<P>{ </P>' m  I# i- }/ b) M% _' C
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
, N( _/ f1 Z- e$ a! a<P>(i+1), </P>6 W$ |2 J2 b) {4 s% v4 R
<P>  (Variant)Table1-〉Fields-〉AsString); </P>
' D/ J; T7 }- l' I9 T" m<P>} </P>
6 i, ?3 @6 B$ r: x$ B8 ]/ L0 k<P>Table1-〉Next(); </P>6 o, u0 B7 C% g0 g" {
<P>} </P>
$ I0 _; F  c6 ]- T( [0 R" u<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>- Y1 S. q( h+ i' m* d$ F
<P>  //保存工作薄,filename是工作薄的全文件名 </P>
! }" v- [; u$ X2 T0 g0 S<P>ex.OleFunction(″Quit″); </P>4 l3 c3 {# z% Y' e
<P>  //退出Excel,释放OLE对象 </P>: D* j/ ]& q6 ~+ A6 F6 a4 M
<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
5 N! L$ x3 v% _- j<P>include ″ComObj.hpp″。 </P>
2 D' l, O8 i4 h  L<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
" y. f# |! k: H; D+ x/ n1 F! r<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
7 p$ r. E& J' k* n7 u$ \& y0 s  L<P>  以上代码在Windows 98操作系统、C++ Builder 3.0下调试运行通过。 </P>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
liunengwu 实名认证       

0

主题

3

听众

147

积分

升级  23.5%

该用户从未签到

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

使用道具 举报

3#
无效楼层,该帖已经被删除
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

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

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

蒙公网安备 15010502000194号

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

GMT+8, 2026-4-20 07:22 , Processed in 0.580919 second(s), 64 queries .

回顶部