QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
" X! J: Z/ C" i! {; E6 N" L9 b<>  </P>
# U& x5 E7 b9 g1 @/ L<>这是从网上下载的: </P>+ z; J, h" x( K" @8 |
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P># f) `, C" }3 t8 p
<>  </P>
" R( {3 N7 |* p* j6 c# _5 m<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
0 R) G& O, Z& T" n+ E* E# w<>  </P>
5 g( Y: T8 [. Q9 k<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>9 ^- y% j% b8 A
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>, f9 p5 h; f. [  z4 A) P
<>  </P>4 }/ U' J; T# f, `/ [8 I
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>& w5 r( q5 w% n4 A$ m0 O
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>
1 @& N3 |) V5 C: I7 I! X$ m) V, t6 b, M! V<>  </P>: b* ]" @* V# K6 J& ~, d
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
& G/ Q2 p6 H" m* Z<>  </P>9 x8 K# @$ e$ d* u, N
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>+ \$ j8 E# T0 E3 H7 L' h: A6 u* `
<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>; R  K1 S+ T2 P2 n
<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>6 ~3 ~, u& u& g8 h4 C+ m( w) O6 o
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>8 Y1 ~4 U% a9 U9 q
<>  </P>
( s, g5 l- U7 \& v$ `, G0 B4 V+ k, N<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>' ]. Z* @$ Z. L4 v0 l$ y/ D# A
<>  </P>% P$ s# h; n& A
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>' Z2 _5 \) F( z$ J  H: }
<>  </P>
# Y# g. i' {: o* r: {<>C++ Builder操纵Excel的具体方法。 </P>, B9 z' F9 O) b# U# |; f
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
- j' v  T3 i( I! n' `/ @<>  </P>: H) l* W2 M' H0 b
<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>) @# `% d. R8 H/ I  ]
<>  </P>' m% B1 Q  l! H. F. W
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
/ n1 M2 d5 n) ^' f  Q9 I* c: Z<P>  </P>
% z0 a3 D. _6 l<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>( V8 ^/ f7 `# i' R  Y! `. r
<P>Button1Click()函数中加入如下代码: </P>
; k. ~* c5 k! {8 a; J<P>   Variant ex,newxls; </P>
$ |8 h$ Q! c, N9 r. ?4 W- Z  O<P>   int i,j=1; </P>
3 B) P  k5 J2 f; g4 [; k$ O+ i, ?<P>try </P>
2 u9 C' H2 c" E0 k8 Q5 H<P>{ </P>
6 Z5 p7 E: p. w3 O7 f9 M<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
$ U, _" k3 L2 B<P>} </P>
' h6 p' x9 x) Z# E  ]; ]( Z6 R<P>catch(...) </P>
, X& P! q2 t9 U7 R) M9 Z! z7 G<P>{ </P>5 n6 d. O: _3 h/ u0 {0 ]. a) ?3 l
<P>ShowMessage(″无法启动Excel″); </P>
* H3 `% ?% L. H7 ^. \( _. G<P>} </P>9 A0 |3 e- H8 ~" p6 ^
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
  r. c$ g7 n5 [<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>5 E- ~% V/ _, U2 k6 O" k, W& L/ V
<P>  </P>- C0 {. M4 r9 b5 P# f5 r
<P>Table1-〉Active=true;   </P>9 v9 e  P# G" S* Z3 B% |$ u
<P>  //打开数据库 </P>* n; v( K" O" }2 b# m) o
<P>Table1-〉First(); </P>
% Y9 ~" t2 }6 L0 l- N<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
  P$ J. h4 g# s<P>  //将字段名写到工作薄的第一行 </P>
- U8 i+ b1 B. q$ F; N# W6 N6 W( V  F<P>{ </P># b' N4 Y8 i' J  n6 n0 b3 c1 g2 d
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>3 w# @7 M, T$ D6 K4 c# z; O' L. I
<P>  </P>9 u) F" x! X' U+ s, P$ D3 C
<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>! x, o) Q6 G3 s5 ~6 Y  K7 [6 p4 x
<P>} </P>3 q3 ^, L5 r: n4 H: m: ^# i! u' U
<P>while(!Table1-〉Eof) </P>  E- v; f2 L/ P1 g: t/ J
<P>  //将数据库中的记录依次写到工作薄中 </P>
% L3 k. y  G9 ~0 s( p<P>{ </P>
1 Z7 X" Y; ^/ X. {) n<P>j=j+1; </P>; |  K! k$ x# |8 a* h  X) P
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>% b$ _4 [; c- P; f* Q5 B! A7 t
<P>{ </P>
. `% Z/ z0 P8 J! S, @) D& k$ J<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
5 s' k) A8 e- u1 s, l* c% {( ?<P>(i+1), </P>
( }# i% Z5 ?2 Q. J" M2 l<P>  (Variant)Table1-〉Fields-〉AsString); </P>* a& I/ {2 s$ y6 ?
<P>} </P>
# B* d+ I8 }3 r7 y<P>Table1-〉Next(); </P>% p: i  ^& Z5 s8 j; b8 x
<P>} </P>& w9 h. m4 _  r
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
0 Q* |; @% {' Y/ L1 t# j1 ?9 M( B/ o<P>  //保存工作薄,filename是工作薄的全文件名 </P>
$ G( w6 d5 C2 k. m9 u8 }<P>ex.OleFunction(″Quit″); </P>9 C9 M$ l: D, Z
<P>  //退出Excel,释放OLE对象 </P>
: r$ T5 K2 K# r- _1 I8 W0 v<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>1 L7 Y' T% n/ h1 Q; E1 c* I7 N' v
<P>include ″ComObj.hpp″。 </P>
; ~( V( m6 Z! N) e; H<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
  a2 O& y- v" T6 p/ A4 U<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>* b+ {' r1 A+ m  D. t) i
<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-19 23:46 , Processed in 0.420892 second(s), 56 queries .

回顶部