QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
4 l; K- Z: o. O% ^; V/ @<>  </P># q. f& C% T, X
<>这是从网上下载的: </P>
: B- S" ^$ `# P1 J& j<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>0 B0 l$ S  c# c+ M8 G
<>  </P>0 J( C5 {! O& |4 ?9 c( T+ o' f" P
<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
: Y: L' t, X+ y" a<>  </P>, L& k+ s2 O6 b8 ^; J
<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>: W0 `6 O3 l/ q+ u# H
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
$ [4 c7 f) y2 k, A# a. x, f<>  </P>
/ |1 n7 V, o% P$ d+ x6 O<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>% q7 ?' y$ t8 K' ?" q( }. {0 V
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>
; I+ n1 p( D. [<>  </P>8 o* }% u9 D9 N2 m0 z
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
  C' w2 Y2 O( W/ N2 @$ M<>  </P>3 Q+ D. p, Y! Q0 c9 O) {) ?* x3 \
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
0 p2 b1 \& o  o; j) |<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>) J' X/ T' j) o$ e8 T/ c. ~
<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>; A4 ?. M3 D1 P, n8 k
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
8 ]" A8 b( a# `- z; J6 }<>  </P>
1 P8 ~+ \$ l- \$ @<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
" ?, E+ ]  V) \7 C<>  </P>
6 Q" m8 K  K9 x5 y! w<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>
: [& t" \7 C0 Q, A" {9 F<>  </P>2 H0 C) e7 G5 \
<>C++ Builder操纵Excel的具体方法。 </P>
7 A1 K1 c+ H  y9 B# C3 F' F" Y% u<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>3 u5 v7 P0 a7 @+ V" f' p" g
<>  </P>3 h: g* r9 T! W# K+ P/ ~1 y
<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>
) W; o. Q) b* ?5 C' v7 g<>  </P>
* C( e1 K& t8 `<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
3 V; y" w2 F, q0 j2 }1 |" O<P>  </P>
" Y8 V# n& a  t/ [. \+ {# o<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
$ j) g; Y# t' w$ |6 R+ _7 G<P>Button1Click()函数中加入如下代码: </P>
) [- j, E9 O7 {) |( k<P>   Variant ex,newxls; </P>
% N! q" _9 c8 L) b6 U<P>   int i,j=1; </P>
/ N0 O* q/ ?% _0 H<P>try </P>( S. R% v3 ^/ q/ ^' s% D( ]5 A' o
<P>{ </P>
+ l2 j- G5 x7 a5 C' O# M<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
4 m8 Y$ m/ V& s) x- @, \4 p<P>} </P>
# F& u" _) y# s$ D% e<P>catch(...) </P>. D! l( E; Y2 A2 z2 c
<P>{ </P>
3 z4 d1 L3 i+ S( d$ n8 E<P>ShowMessage(″无法启动Excel″); </P>; a% N! V4 g# P0 A7 |' ]
<P>} </P>
0 S$ l' i& E. O: @2 k1 s! o<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>3 v2 _1 a4 P0 w8 Q. y
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>8 p7 x% Q3 ~# Y5 E) ~' Q
<P>  </P>1 C' H2 e5 b0 O% g- r
<P>Table1-〉Active=true;   </P>9 z7 C8 G, H/ ^7 u2 W, b
<P>  //打开数据库 </P>9 X$ u) U+ J' S2 l, o( X
<P>Table1-〉First(); </P>: j: p9 P8 ]" N4 Y! S/ f  e6 J0 T% x
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
) N# d; J, }& ]3 Z# V% m<P>  //将字段名写到工作薄的第一行 </P>5 o8 X. l" R/ f6 H  `6 T
<P>{ </P>
5 u- q1 `' c; P" G& N<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
, I8 D7 Q4 H0 ~$ _2 M6 u6 }<P>  </P>
! U, ?# v  B1 ]: B; r) `<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>. [6 Q% \; c: }
<P>} </P>
( P  V$ e( `1 n2 B7 y5 [<P>while(!Table1-〉Eof) </P>0 t/ {8 ]3 s* q( W+ N, A9 g
<P>  //将数据库中的记录依次写到工作薄中 </P>
' H, T, B1 V+ M. p! h, s" w! X, k- \<P>{ </P>
- }8 Z) _8 X* d( Y9 ]5 Y<P>j=j+1; </P>" S8 `2 {: _: b/ v8 e+ U' A, k
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>9 k' k7 i5 y# j1 W' P
<P>{ </P>: j6 `& B3 C. M# w+ U2 ?5 W  \5 b
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
1 F8 I* G. s: L' a% G8 H( C<P>(i+1), </P>
( x, |/ C! X5 b1 S0 a/ G- D( e8 d, X<P>  (Variant)Table1-〉Fields-〉AsString); </P>
- B+ A+ H$ r3 L# N  F<P>} </P>
6 |( @% J+ N% G<P>Table1-〉Next(); </P>
7 k5 ^: ^% h. h  j7 ?* C* Y<P>} </P>' f( F3 x  E' u: q7 n% A
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>% P& W2 _, Q) y2 i+ t$ X" y& z8 l9 H
<P>  //保存工作薄,filename是工作薄的全文件名 </P>
3 u% x+ W/ }  E3 X4 T- t<P>ex.OleFunction(″Quit″); </P># f! n' b4 C& n3 J
<P>  //退出Excel,释放OLE对象 </P>9 r/ V; G2 t2 Y7 e9 L
<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>5 Z7 y1 U) t  [/ F- Q# l4 |
<P>include ″ComObj.hpp″。 </P>
, s" F) b0 `. D7 ^7 e7 S: Q<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
, h3 o+ K1 _/ `) M1 p. \, Q! ?# o, A<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>6 s# \0 ~+ }: s+ F; ]
<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, 2024-4-26 22:13 , Processed in 0.456334 second(s), 55 queries .

回顶部