QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>& C) M0 A. _; Y4 }0 R; d4 l3 _  q. S4 _
<>  </P>" m5 y3 p: T! R. V
<>这是从网上下载的: </P>
8 c5 Y. T( W: A+ D, |<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>  }7 q1 v: B7 G0 x0 r( I+ \
<>  </P>
% q) j6 i3 i1 j* X<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>* W. N! W8 z% W+ q7 G2 P) c/ u
<>  </P>7 r6 F- A4 w6 j$ Y+ @
<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>0 p9 a' ^4 ?5 q7 n! A
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
; @, X; Y+ ^3 q; s* r/ q4 _+ L) F$ @<>  </P>  }5 ^  E* o3 j* I7 n+ Z) V0 Y
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>
9 y5 ~, ^# E) m; P9 C9 o<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>/ Y# O6 d* z& N( `/ P
<>  </P>
. q* b$ d$ ~2 X6 K8 x  j8 V' v# Z<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
7 W2 |( S7 U: }/ @2 l' }6 Y<>  </P>
' M1 r0 l% p7 e& e4 {5 k<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>9 o6 b* S3 w/ [" R. H. d3 n
<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
: x2 \, [( s: b0 {' u  G% O  c<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>1 m/ g$ X$ J+ ?0 y, A
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
* z8 S+ ~% r9 ~<>  </P>" L  j( a# H4 f
<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
, M. Z& H; E( f+ A% K" D  q9 e<>  </P>
! L& s. ?4 `- w* i" ^( T<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>6 m6 b% V) m7 q* v5 `
<>  </P>
! W6 H) o% r4 ?% h# G4 y+ j+ \9 r<>C++ Builder操纵Excel的具体方法。 </P>
1 b2 e8 l9 L: ]1 O( n* d+ ~<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
  P: w  ]9 D3 i* |* ?' X$ C<>  </P>9 ]/ g( s1 H" a" Z3 [6 `! c! H, s
<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>1 R$ {+ x$ q# z8 l
<>  </P>* ^. {, Y, `: R& s, w6 r
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>' u3 @( k: ?' ^& L" e( {9 ~& v# t
<P>  </P>0 y% v* x7 S" q# F6 ^5 `9 U' ?/ Y
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>' x. v5 d# A* X$ d6 ^0 O
<P>Button1Click()函数中加入如下代码: </P>! U/ U- S+ t9 G  |' }: E+ R! r: H/ C
<P>   Variant ex,newxls; </P>8 A( t7 K; p8 I! L+ P7 x  b
<P>   int i,j=1; </P>" `0 D+ `4 R* P5 Y" \5 S
<P>try </P>. l. |9 p7 b0 Z2 f3 }# N: L
<P>{ </P>
4 d6 I4 l0 V( O1 r, H7 W4 e<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
% y/ [' T3 ?( c" h" a0 W# I" `<P>} </P>: W' k8 e; ?+ D4 E  w
<P>catch(...) </P>
( e7 e: g! j3 s4 `<P>{ </P>- W1 k4 w: K' @" c
<P>ShowMessage(″无法启动Excel″); </P>' V( B% U6 o0 `0 v
<P>} </P>
2 z' ]6 s2 H4 K9 b  f9 F<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>. M! n0 {% s( M% m6 r( O0 A, a
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>
+ f0 ]! E0 V- ?8 ~<P>  </P>
6 \) ~8 [; i* N* Q- u# [# ?8 m3 t<P>Table1-〉Active=true;   </P>
0 H; h% ]* P; t3 C$ C+ o<P>  //打开数据库 </P>- _$ w/ I1 f0 I$ i
<P>Table1-〉First(); </P>/ ~# N' C. n) Y: ~% _& m( H
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>/ `8 p. m. P& N
<P>  //将字段名写到工作薄的第一行 </P>9 C4 x, |9 a' c0 {& x
<P>{ </P>
2 b: Y  R  q! ?; S- l- `! q<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
, c" E9 W( ?( a: H' h- g& }<P>  </P>
* _: ?7 m0 l% A  ~<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>% A4 o- j- y9 ?& R4 l
<P>} </P>
8 A. [, k% P" u<P>while(!Table1-〉Eof) </P>
+ x. s. f' c# J- n; k. b' ?6 k<P>  //将数据库中的记录依次写到工作薄中 </P>
% A) P/ X8 U* @5 o( H8 Q<P>{ </P>
3 ?* k8 V4 o- g/ d; x7 m<P>j=j+1; </P>
9 t- h! q, v2 C8 _<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>% ~5 d3 v. B# ]& d1 L) v
<P>{ </P>1 v4 |' _* C7 G' I
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>" \2 ?' h" Z! |2 j, V7 o
<P>(i+1), </P>  Y" {' P, l) o$ o. }
<P>  (Variant)Table1-〉Fields-〉AsString); </P>
% S& F. j' O5 t8 ]<P>} </P>* k6 c3 L9 K6 ~/ o% f& {
<P>Table1-〉Next(); </P># U, L7 E) ]- S* ]0 `
<P>} </P>: `: q8 Y4 w; a/ r8 I. Y% I; @9 L2 S
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>" L/ N2 Q$ M# _& c- l) n
<P>  //保存工作薄,filename是工作薄的全文件名 </P>" U8 d& A, O  }& ]) `. n
<P>ex.OleFunction(″Quit″); </P>
0 n0 X8 o* }0 G! b* B# n<P>  //退出Excel,释放OLE对象 </P>
! b7 s+ B8 l, V+ R3 g. [9 D3 D<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>) @5 N- X  K9 L" r+ S/ i* p
<P>include ″ComObj.hpp″。 </P>) u' z" Q( v# c, ~3 ?" r. f
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>. o( |( d1 T: }& F
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>6 {4 e- `1 S" F2 b+ I, D7 R
<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-11-10 18:45 , Processed in 0.500119 second(s), 56 queries .

回顶部