QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
5 B" N0 E) l( b. H) @, c; H<>  </P>6 P* [. s8 Z& @& {+ ~& y' W1 J' @
<>这是从网上下载的: </P>9 H0 X" ?. \$ H- r
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>0 O) Z& `5 C3 @8 p3 o/ w
<>  </P>
, ^3 ~7 w4 r- ?6 L' c& U<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
/ R2 H' Q8 W% p( S8 L3 ~5 ~<>  </P>4 K- \6 X0 U% f8 }  i4 Q! D0 o6 z
<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>
; c: ~* c1 k6 {<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
+ q$ e$ {  [! l% x" ~: m<>  </P>
; O5 u( [3 V% V. R& s: j; @<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>6 O, V& H7 q; o1 T6 S2 R+ p$ f
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>1 L1 ]/ b' Z, ~3 B& R0 d. H' B) K$ c
<>  </P>
# n8 f6 B; W* D2 [. v% ^  e  s<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>0 n2 n+ _$ L" w
<>  </P>2 W! I. ]2 k% u4 _. ^
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
" l# V+ d, U# p+ D; G9 [* C, X<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
+ s8 g0 H5 a, l6 T* N/ _: ^: N<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
* x) \4 h. n4 x: [7 z. b  ^2 F5 w. v<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>2 [" m, [$ _: X, x* @
<>  </P>
9 R/ C1 P. ~3 r& W<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>3 ^. s* B! H% }3 W- H! `/ M
<>  </P>4 a. {3 Y/ p  ?8 y- V
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>, Z8 r) ^9 M* K3 [$ ~
<>  </P>$ |% L* J! j$ i% D6 y. ^2 z
<>C++ Builder操纵Excel的具体方法。 </P>
+ p" ]7 j( p, Z<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>7 f7 O) I% b- }9 l, n6 k  L4 G
<>  </P>
. O4 A  v( {1 _4 h4 P* L<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>
% B+ x/ L7 V( e9 m<>  </P>
0 D* n/ s+ z3 R$ c5 i) h8 d2 m" o' R<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>. k+ z$ v$ l2 i
<P>  </P>
+ _. J6 e: w. Y! K  {<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>( a$ B  \, R7 D
<P>Button1Click()函数中加入如下代码: </P>/ ~0 J$ F( T( d( ?3 i
<P>   Variant ex,newxls; </P>
) Z4 ^5 R, H" N<P>   int i,j=1; </P>5 O. @7 T9 F" ]* g
<P>try </P>
; t. A  l& R" ~2 Y( F<P>{ </P>7 K# X/ `5 R4 L6 @9 Y* `
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
  s. S3 S2 J4 i  D<P>} </P>
2 n3 E2 U7 b+ K+ E2 Z4 j( w, b$ _% _: {<P>catch(...) </P>
" a9 f. M) I- o<P>{ </P># J4 u7 Q; \7 }& s+ H
<P>ShowMessage(″无法启动Excel″); </P>! X+ a; ~: }  }; \5 ]4 C& P
<P>} </P>% V4 D8 F. T" j% ]/ X
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
$ u6 V3 D& E- d$ n: r<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>+ ?+ O- V5 X: [) N
<P>  </P>) p. o( h2 V( K  H6 k
<P>Table1-〉Active=true;   </P>9 T: {6 f5 {! Y& n) N8 S3 r
<P>  //打开数据库 </P>  {+ |' s& Q. A
<P>Table1-〉First(); </P>
0 X# T% W/ [2 ]; ]7 o2 @& P<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
7 `, T! |$ D# O! V1 X$ a4 d% S( X<P>  //将字段名写到工作薄的第一行 </P>+ J9 q0 d  a1 ~: L
<P>{ </P>3 \7 S  n: Y3 r" g$ U8 Z
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
1 ]# Z# }" i$ i- d5 T<P>  </P>4 ~8 W. w, E: r  Y
<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>
& X' d& `' m, B. R, v( H/ A; j<P>} </P>
3 U" ?9 z5 e) l% u( i% a2 i<P>while(!Table1-〉Eof) </P>6 {" ^) X8 O* T
<P>  //将数据库中的记录依次写到工作薄中 </P>
/ m! g- {+ C0 w. J! Y5 _: L<P>{ </P>
. Q* z0 A5 d$ a7 b- S<P>j=j+1; </P>  K% s( b2 R( I* v! L
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>/ E0 i& X9 y; U5 Z2 D" U! N: N
<P>{ </P>
  X2 U. x- V" r: V; N<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
& n/ N8 i# Y; P: g* h7 l<P>(i+1), </P>
0 g" [! b- e1 ^9 A+ v* U. p<P>  (Variant)Table1-〉Fields-〉AsString); </P>
# W3 g: W2 v: x  g3 L' ]2 P. N2 q<P>} </P>' w/ a: d; m" W# s; V6 F
<P>Table1-〉Next(); </P>
' _; R; G5 }- m+ Q- |<P>} </P>
2 h4 ^" K: J& y5 ~- D' S0 K# U<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>( C8 W0 `6 _: [' I) Q2 @
<P>  //保存工作薄,filename是工作薄的全文件名 </P>5 o4 L8 ~  ^  s0 N" A, t" ~5 q+ z; h
<P>ex.OleFunction(″Quit″); </P>8 q) m$ Q: }9 b3 d% B5 o- |. ^+ s
<P>  //退出Excel,释放OLE对象 </P>
( k% m1 y' X! O2 J- h<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>$ ]( V; C# |7 ~$ P) O' M
<P>include ″ComObj.hpp″。 </P>
' x. Y6 `- D" F; l5 V# H<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>. M, K  ]2 A% x/ g2 q' u
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>+ g9 ]' H: J; o7 S' D6 n
<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-5-26 00:42 , Processed in 0.390289 second(s), 56 queries .

回顶部