QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
' ?7 X$ t3 _: `. G; E" t8 C<>  </P>
' Z  P  @  I3 S<>这是从网上下载的: </P>" U0 R' q# u# v" v; Q" E2 u
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
  Q$ O- b; Q: v. R) T4 Z) w- o<>  </P>
  m0 Q5 j/ @  t7 A' h<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>0 f. ?2 L& C# K* L; a/ y* S
<>  </P>
- [  ?' b% A% |# y<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>, C$ l9 e/ C- m+ y. j' W% E
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>  T9 F# g5 I  g
<>  </P>. u; {4 T1 C; b& K  X0 A# v
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>
% m& N& b' ]  ]& ]4 [' d- _8 X<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>
% s2 E1 Y* \; n# \6 _  n3 a<>  </P>
  ^  l2 p/ ~" z9 _3 Q' G9 a<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
& ]" u3 o( f: g0 L. K+ b<>  </P>2 ]/ o2 X; S* Y* A
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
+ y8 O; i! C3 {<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
: q! A4 ^# r" |2 x; ~3 S2 U: T<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>' Y3 s% Q# E  I5 {8 l( T' ~2 Z5 o
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>8 H6 T0 C8 q) d2 U: S0 l$ [
<>  </P>  @. N% O$ k) k
<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>0 K7 ]! D, X% l; m3 w5 T" J
<>  </P>; L# W- N( d" C: L/ m( x' {
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>
/ ^# F2 a# w: _4 y5 W3 A0 Z; d. ~<>  </P>! t9 R* V) z( {9 J( y, d" a5 |
<>C++ Builder操纵Excel的具体方法。 </P>
7 d6 u1 h( r! \  ]" w6 i<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
1 Y& ]" g: j" Z2 k<>  </P>
2 Y2 T7 o1 e2 _6 M<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>' a' q. Z2 f' S/ D9 C4 l$ R' B
<>  </P>
7 ^1 J7 t5 l$ h; ?1 p<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
: [9 a8 }) d, y$ y<P>  </P>
2 t6 v/ z( Y6 \4 `' u9 V- |<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>) p/ F, x' A  b4 E7 [8 G, Z0 [; M" u
<P>Button1Click()函数中加入如下代码: </P>
* Z) b2 g, ^( m9 t8 w. S<P>   Variant ex,newxls; </P>
* S  x& Q, _1 D<P>   int i,j=1; </P>
& }9 ~2 C; D3 z$ f<P>try </P>1 L; y4 t, Z2 X
<P>{ </P>
, C. n* v+ n$ k0 I; W<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>' b6 A# S2 }! b; L! ~
<P>} </P>
. `7 [6 L& Z2 l4 o. d: y<P>catch(...) </P>: @# {# S9 @" {, c
<P>{ </P>1 N: R. W1 O7 o! v
<P>ShowMessage(″无法启动Excel″); </P>
+ ?- U  s0 I. @2 `0 t7 w8 S<P>} </P>5 }5 w- `* Y9 h$ v0 g/ C
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>/ P4 |) ^! ^+ _( c& j4 N
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>
: \& E! j- i  ?! h% q5 k<P>  </P>8 q; K  l9 L% A( m; o+ o
<P>Table1-〉Active=true;   </P>
1 O! E+ j: [; F  x1 ^& r<P>  //打开数据库 </P>+ I: _& |7 E1 d9 n
<P>Table1-〉First(); </P>+ U- a( J+ n  U
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
2 Z) T, D' [# e<P>  //将字段名写到工作薄的第一行 </P>( m4 J+ }2 ?6 s5 ]3 c, {7 ?
<P>{ </P>
( W. I& U9 r+ T+ U& v1 ~  f<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>3 c. h- i+ w+ N7 x) K6 S. h
<P>  </P>, l0 N, l) o% Q
<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>3 Z& q  Y% ]* V6 y: J
<P>} </P>& f: G2 z. [, s: p
<P>while(!Table1-〉Eof) </P>
0 T( a* M4 l( c5 A, V<P>  //将数据库中的记录依次写到工作薄中 </P>4 e3 {- b- z+ F) x
<P>{ </P>: }( p3 a7 v7 i8 F) [: f
<P>j=j+1; </P>
. h1 E) v; I5 J( o' n- A! _* W<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>0 i% E7 x6 L& T  K& Q5 K
<P>{ </P>/ V# h* C6 z, \5 s
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>8 V3 O: k) G5 p) c: r
<P>(i+1), </P>
, ]& q! o5 B. a<P>  (Variant)Table1-〉Fields-〉AsString); </P>% B0 B- ~3 V3 [; Z
<P>} </P>
; X& W. d' `+ ?<P>Table1-〉Next(); </P>, Q. i9 O" @  e! F/ p0 f' q0 s8 N
<P>} </P>( j( H' w9 {7 u$ X9 T# J+ K
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
1 T( j  K1 s9 r5 a$ f<P>  //保存工作薄,filename是工作薄的全文件名 </P>" T3 r7 b) v) ]
<P>ex.OleFunction(″Quit″); </P>: E0 I7 r) ]6 x; q1 U1 A
<P>  //退出Excel,释放OLE对象 </P>
* ~" G0 F1 @" D/ a( s$ f! J<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
$ I8 [3 h. l* F% y1 c& S6 m<P>include ″ComObj.hpp″。 </P>5 k( N$ K' ^! j- n$ b
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>0 O" w4 ]$ [3 m- X5 [
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>$ h& W9 A6 Y9 [3 b) Y  o) a
<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-19 09:10 , Processed in 0.449859 second(s), 63 queries .

回顶部