QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
, J. p+ o! U* l& c0 b<>  </P>& S+ b9 r5 u8 E9 h0 ^) j) l" V- Y' _
<>这是从网上下载的: </P>' K: V7 e. I: p! G  E' Y
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>4 M* |8 P2 k0 x0 }" d) g
<>  </P>
3 R  @( Y/ c2 O9 [3 H' G0 q<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
; n8 }: b0 `' `4 a3 x<>  </P>
# Q% ?8 ^. v; n<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>4 c% l: L1 ~2 t+ C: q# \$ I
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
; ]. ^( y7 ~- E; u( A<>  </P>
- Y0 P7 ]  g- S<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>
$ A6 f* ]8 j- ]1 e: ~& {9 P, B<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>
- g0 d( b3 r$ y  b% h" O<>  </P>
+ o3 G" x0 H; J; `7 i. g<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>1 b- t% O* W8 b
<>  </P>4 o6 M/ e, T: _$ i3 X+ s2 m
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
; W/ {& X  N" G  Y/ \! S- |1 s1 e<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>" Z# y  F( @% C/ H) B/ {( I
<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
9 H" |/ u' d, z, |+ N' d<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>! @+ g+ H& I( o5 S7 k4 l
<>  </P>
* W; u* B6 f; e9 ?3 _<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
5 C2 i5 e" |! L5 J- U1 Z' ^) Q) N# X3 Y<>  </P>
3 u. f* E% p; w/ x! d% X8 V$ A. t<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>( Q3 ~' v: U, z
<>  </P>3 d8 g3 P% Z$ b& r/ t' L
<>C++ Builder操纵Excel的具体方法。 </P>5 [- N2 ^- f5 Q+ `* ]0 N3 S. R
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>& x  T: X& A; @" N" X
<>  </P>
1 m4 L% Q6 _2 u; B, p<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>
2 [7 e; O* A/ t- a$ A<>  </P>8 O+ D4 ?5 E2 T/ J% g0 I
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>( n: e- h" t5 r$ J
<P>  </P>
( t1 v2 _. ^) }<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>; q7 |8 t2 |: r; y. g6 y
<P>Button1Click()函数中加入如下代码: </P>2 f5 }7 _; U9 F: D
<P>   Variant ex,newxls; </P>0 E* P3 u9 C5 u* ?1 a3 {
<P>   int i,j=1; </P>
/ z  Y* r& h# P<P>try </P>+ V  Q1 T, l8 M) q, f5 y3 V  F
<P>{ </P>% u  \8 Q* O: b+ j  k" O& z
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
6 d- d, Q$ ^: R. O, I% v; R<P>} </P>
4 h4 o4 g# t; ?+ L# L8 Y+ W+ b  C<P>catch(...) </P>7 r# [. B3 L( P! B6 y
<P>{ </P>
# ~. e/ M8 B8 U' h+ K: a# e/ r<P>ShowMessage(″无法启动Excel″); </P>
+ y9 l7 P3 C5 ^7 ~<P>} </P>0 }* A) V# g- ]5 G3 \; |6 ~
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>( x1 @! H/ v3 e# }3 {* n; \
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>1 B( ]4 X! A7 H) z4 m5 ~9 l
<P>  </P>
/ I0 t$ N# B. e& \<P>Table1-〉Active=true;   </P>' u* F' G  }4 F0 t- m6 y
<P>  //打开数据库 </P>* i- O; i/ U; d4 F& @, [. I
<P>Table1-〉First(); </P>- o  R$ f* L+ @3 i
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
" p( o9 B8 l+ d<P>  //将字段名写到工作薄的第一行 </P>
! O2 d  m2 {3 M  X<P>{ </P>' ?" L' d5 C; Q/ Y
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>: a- s( f1 t" V0 {
<P>  </P>
$ r% }" M6 q# d' g2 z  u( ^  R<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>
5 r# K! z) w8 n! q+ f- D: m6 a<P>} </P>$ x$ F1 I& M% Q7 e4 S' t6 }
<P>while(!Table1-〉Eof) </P>) C; W' |# r  m
<P>  //将数据库中的记录依次写到工作薄中 </P>
" b9 U# j' o% w/ K* A/ H1 r8 L0 p% m<P>{ </P>
. p( g/ I6 U$ K* v* b4 O<P>j=j+1; </P>2 k; V. o4 v- g& g
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>: ?+ @+ V" ?' E2 @0 {
<P>{ </P>
0 Q' c# q$ Z+ f<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>& o! O, ~' s7 J- M
<P>(i+1), </P>% W7 E# k$ S' Q- F# L
<P>  (Variant)Table1-〉Fields-〉AsString); </P>3 s2 E# ?. t4 ~, w/ @' Z
<P>} </P>1 I: e7 n# t! |0 v! ?5 K( J) b
<P>Table1-〉Next(); </P>
6 F8 F( o3 x1 U& {/ t: T7 ~) P<P>} </P>, D3 N" i/ A4 k2 D! }
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>% W& B" m, R6 C" G- m
<P>  //保存工作薄,filename是工作薄的全文件名 </P>8 T% {0 k4 z+ A& h
<P>ex.OleFunction(″Quit″); </P>$ [8 G) n6 D0 e8 S% ~
<P>  //退出Excel,释放OLE对象 </P>- `, C  U  y8 t+ ~4 k
<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>- @# s% o9 F+ R' a! ?3 w6 N
<P>include ″ComObj.hpp″。 </P>
/ X7 f8 t9 ~; X% x$ _. z; {<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>/ q/ z' L" X2 @- m
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>- \+ b$ s* e0 l8 [
<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-6-13 23:54 , Processed in 0.450251 second(s), 56 queries .

回顶部