QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
9 c/ i! A4 F5 V$ X<>  </P>5 B- _7 ^$ |. M: j; N
<>这是从网上下载的: </P>
% E* S8 C1 w5 d<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
9 _: L9 e$ Q3 y3 p<>  </P>. ?. ]1 @0 u6 Q! m
<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>& P' E2 F& M3 P
<>  </P>. B! V$ I% G* y7 p4 m% q
<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>% `" O( k6 J0 b: I  K( W/ G8 W5 o
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
2 f; g' e9 j4 ~6 R# T" k1 h6 ?. y<>  </P>
8 I. s9 F0 `* m& L8 c<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>" m% Y- Q8 u% S, ^/ b
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>
1 [' {+ g' u( Q$ Z<>  </P>
) b* s- ^2 }6 w' c6 c<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
9 `# n+ x0 l0 y" L5 |. r<>  </P>
3 N! p6 D/ U- ~! A! r<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
8 B& p6 g1 `  l/ o8 A<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>( F7 |4 H; M8 t# O
<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
% _2 S' ?+ a) [. w6 y<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
8 ]& t. L: }9 ^, k5 e) I<>  </P>
+ X$ W4 z3 J7 _  Q  L; h$ }<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>0 _7 k# W3 y; H4 S
<>  </P>
/ v; O6 @/ l9 d8 |5 x5 K9 Y* g<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>
& s, p' |5 M: i  }; n, }: @6 M- j0 A<>  </P>
' s  G2 C/ i9 b) F  ]& y3 x<>C++ Builder操纵Excel的具体方法。 </P>
+ m! ~5 {9 U% u& q3 ~& [: }<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>) S0 R' ?2 `4 A, n
<>  </P>1 A( d- a# o6 V5 c2 s, P, h
<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>, y3 o0 @: e' m, I1 |2 ?
<>  </P>
+ S0 G( i* R8 z% q8 O9 p<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
$ w; C' }) K3 @+ X9 ^7 f; d0 O! X% g<P>  </P>8 k/ g3 ]8 q- h* w, S  s$ G
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
3 q: @; b+ ]$ a- {/ v! r$ g5 j<P>Button1Click()函数中加入如下代码: </P>
* r/ y3 [, u  A3 l! _9 k7 w4 e<P>   Variant ex,newxls; </P>& r& u1 F4 |) r
<P>   int i,j=1; </P>( y/ H+ H( T  T8 W
<P>try </P>
9 b2 y( h5 k. C1 r1 `- t! ]9 x<P>{ </P>7 h  L4 T& k2 c  E$ T& k  q
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
! v: Y( f! U5 I& T: }<P>} </P>
1 p( d% k* N( |. P8 y<P>catch(...) </P>1 j- a3 ?: u$ q- `! N
<P>{ </P>
$ C8 T* W1 n0 G, D% Q2 W<P>ShowMessage(″无法启动Excel″); </P>4 s2 f) p4 ?. o! a* }) B8 S
<P>} </P>  [9 ]: h* W: H( D' l
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
+ w* |  Q% L: s: a5 d" i; o& ^<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>" E1 V* C( N6 ?9 T% I& p: t0 c) e. K
<P>  </P>
1 J9 ^3 r6 F- z. H% ^4 P<P>Table1-〉Active=true;   </P>) U: D! }" Q  `2 {/ z
<P>  //打开数据库 </P>, ]$ Z6 b2 ^. x' P7 n& U9 g) n& F
<P>Table1-〉First(); </P>5 K6 l5 R* Z6 @& r1 B+ b4 B% L
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
6 G- C# z  ]4 V  M& c<P>  //将字段名写到工作薄的第一行 </P>( f0 i8 {( V2 r' ?8 K
<P>{ </P>
6 ^$ ~1 C- e" S% S3 u<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>( F9 w% n5 j" y1 [2 q; ]# e
<P>  </P>
6 Q1 u1 s# R( s0 h  @! z<P>1),(Variant)Table1-〉Fields-〉FieldName); </P># e. B8 w' v8 e: Y7 b
<P>} </P>
, j" |& L: e* S4 H4 c& O6 `<P>while(!Table1-〉Eof) </P>1 p; i2 P; ~" G! t6 E
<P>  //将数据库中的记录依次写到工作薄中 </P>! w* v5 d# ~0 @2 H* }/ h
<P>{ </P>
) b3 U* ^) l3 @. E6 b<P>j=j+1; </P>
& u) r5 x2 E2 P& a' `% u0 n7 J<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
' f! }, y/ G4 i' ~6 @<P>{ </P>
6 p) a/ u: Z! u- P<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
* |% H8 d, n" l2 ^<P>(i+1), </P>
3 }, E6 g$ C! h<P>  (Variant)Table1-〉Fields-〉AsString); </P>% k; m5 D2 o- X3 u$ x# \
<P>} </P>
- J) L* i0 i, N) K& j5 ~<P>Table1-〉Next(); </P>
- T* P2 S( _7 ~' u4 P' U# r% u<P>} </P>
+ t# L( g; |- L4 I<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
! {& S- y+ x5 r% P6 x! o<P>  //保存工作薄,filename是工作薄的全文件名 </P>
1 u6 q% ]. w! {, T3 Z" z" I/ {' L0 j<P>ex.OleFunction(″Quit″); </P>
5 t8 F2 ^7 f6 o# d3 c3 x<P>  //退出Excel,释放OLE对象 </P>
! w9 J) h% ?' f! x<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
, X! g, a+ y6 ?<P>include ″ComObj.hpp″。 </P>8 C0 a$ S& H& j6 M5 U0 M
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
8 u% ~+ w/ S0 y' m2 U% m<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>: ~5 d, l6 {* s! O: B) P
<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, 2025-5-11 16:52 , Processed in 0.379222 second(s), 68 queries .

回顶部