QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
#
发表于 2005-1-26 01:22 |只看该作者 |正序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
% H' Q* ?! U. O/ n, r7 m5 P<>  </P>7 Q6 ?7 u0 W7 ?; R. p8 T# w) w
<>这是从网上下载的: </P>: p2 h2 }6 k  q7 ~, U5 J0 H
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>1 c% U" L1 s! m
<>  </P>
; B3 E# y: n; T& C' W6 [<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P># H6 ~" q- H5 _3 j
<>  </P>
* G! g4 \* }0 |! I% L: O<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>
; n2 W1 @/ a, M7 ^4 D: |/ w' R  y<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
- P4 a& J& N* z( y2 A<>  </P>& V6 M9 F$ r9 S, p/ N, s6 u
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>2 E" O* _8 x) |: l9 k
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>9 {/ A4 z; M- u6 o
<>  </P># O7 {! u9 S5 ]' I2 k( L: I/ R/ J
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
" k( X" y; o) m4 b<>  </P># X7 O! x# k" v6 o% a8 P
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>8 |, D3 }" }" ?! @  @6 p
<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
/ Y9 b4 E& ]1 ]<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>" c% d1 o7 @( _" u/ i8 Y
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>) G/ A& J) }2 @5 `$ J3 k# B
<>  </P>% L2 O* d5 k8 Y" }- v% t
<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
; K$ p+ U' m4 @" l0 g) \; c2 E<>  </P>
6 q+ {! F. h& j0 k& d' c<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>3 ]7 m; i! g9 z6 P* N0 @
<>  </P>$ k' I6 D( {" ^, x! x. _
<>C++ Builder操纵Excel的具体方法。 </P>
- V/ ?, I( X8 _+ O<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
2 y; C3 c& _* _; j<>  </P>
5 K% t4 Y  n  g<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>* ^- k, v. ^- D/ n6 K% }% \
<>  </P>
$ u) f6 X1 Z" T" c( {# S, C<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>$ B- G+ s" j! b. y
<P>  </P>( {. H$ g; b) w$ H" O4 a4 J
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
/ D) z, e2 A$ g; l4 W<P>Button1Click()函数中加入如下代码: </P>/ C+ [8 j" _/ S4 F
<P>   Variant ex,newxls; </P>
; m9 o2 Z+ v. I0 ~( x9 \3 ]<P>   int i,j=1; </P>7 D* ?. |, E; p2 y% x5 g
<P>try </P>
  {9 R6 M1 y; b! r0 N$ I0 o: n" K" x<P>{ </P>
9 \+ O" f) F" I3 `<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>1 d. `9 b. [+ |1 s2 r
<P>} </P>" b+ }" c5 u* R6 {) r$ {
<P>catch(...) </P>
/ D. y& i7 F, i, c8 R<P>{ </P>- t9 A, r' k* P0 e" M- D' J& q4 ?
<P>ShowMessage(″无法启动Excel″); </P>
. ?# [0 W) ~7 d* N+ s' L<P>} </P>
: m  F6 Z0 x/ D<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>) N0 N& @1 R  d9 u1 a& r2 ~
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>$ L/ P; V7 K+ h& r
<P>  </P>
0 W! D& d) c8 {2 ~  Q<P>Table1-〉Active=true;   </P>
3 T& Z3 ^. C( t* d7 O8 d$ Z<P>  //打开数据库 </P>
- ]/ A) _8 y3 e- @" q, A<P>Table1-〉First(); </P>
  [1 b# f) \/ p<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>! B: A3 N! L- V& S; P3 w4 X! b- f
<P>  //将字段名写到工作薄的第一行 </P>
/ N  F& l2 Q$ b% j2 P! A<P>{ </P>0 @! @! b7 t, f5 I  x1 U9 e
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>% q7 o$ i7 t) [, s. r- _% P
<P>  </P>" _- x" r. d. u3 \1 C, q% Y
<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>
( v7 ^6 q0 ~1 C$ l1 M: K7 F<P>} </P>
. s, U6 d; }/ F5 r0 N3 c<P>while(!Table1-〉Eof) </P>
9 F1 N4 m) G5 v+ S2 C/ @# C, p& U<P>  //将数据库中的记录依次写到工作薄中 </P>0 q) p# ?2 n. ^, \
<P>{ </P>
" t* Q( U* F. W  @; k. x: o- j  V<P>j=j+1; </P>
% `" x) x6 G0 `/ H<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>0 s+ x2 g0 a( R
<P>{ </P>$ l, P4 f% F0 u7 P& \
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>' P; E3 y4 P7 W
<P>(i+1), </P>0 A6 ?/ A& d9 r; t  g, W9 q1 d, R
<P>  (Variant)Table1-〉Fields-〉AsString); </P>' ]$ H# B) Z! j$ m- M+ z7 L
<P>} </P>  K: c9 k+ E' c( u) I# r
<P>Table1-〉Next(); </P>
  d6 Z+ A8 E# V1 u<P>} </P>, e' w- n6 B: Q$ o6 y: z
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>+ z2 R& A9 E6 Y
<P>  //保存工作薄,filename是工作薄的全文件名 </P>
7 c& `# g0 x; Y3 s<P>ex.OleFunction(″Quit″); </P>3 f8 f! r& A6 w* t
<P>  //退出Excel,释放OLE对象 </P>
9 ^, ^$ P+ N+ n- l, P+ h<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>! A0 W+ w$ u! R% P, N3 Z
<P>include ″ComObj.hpp″。 </P>* ?5 y3 S; D' ]2 C
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
; Z- ?% Y" M: k9 Q<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>; |8 T0 b: V/ f" z; v
<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 15:03 , Processed in 0.449389 second(s), 56 queries .

回顶部