QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>5 W/ O7 \' h8 n' B' z
<>  </P>
* V* b) ]" ?9 K3 ^! J) {! ~  W<>这是从网上下载的: </P>' E/ t$ @( _+ o2 e/ R
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>1 \$ L. ]9 d3 s/ O
<>  </P>* `' ]: T) I& m% E1 e. a& h' t" p- z. B
<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
' n$ U8 Y' @0 T: c; D: C. r<>  </P>
' h( I+ F1 B) m9 T4 w<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>
; F  X, d5 W" {<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>; \1 u" y6 @2 n+ X
<>  </P>
+ w8 H* }" @% p2 \9 X<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>3 f# \9 P8 V8 Y0 C, Y. o2 S( O# a
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>4 P( m5 ~/ K1 R) l" K1 ^  h
<>  </P>
8 Q4 d: M( s$ `, E<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
+ H' F6 W( Z( y4 ^<>  </P>1 e* Z$ b1 x; o3 H
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
9 |  B, i$ k# {; k, a5 t* V<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>+ r6 L+ n8 w+ F4 m
<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
1 ?. a1 k- F3 H& K- ^* n<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>. Z$ R3 ^& G$ F/ B' d& d. a
<>  </P>3 f3 ~' ]1 j0 \% ^
<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P># V/ [( h# e* `/ Q0 V( @! z
<>  </P>" @1 a% Q) [+ Q4 P) k4 }% v
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>
7 U9 U# `- q" {2 X. |<>  </P>
7 e- J- l3 Q# C- V1 ]0 v+ M<>C++ Builder操纵Excel的具体方法。 </P>6 W) C$ Z) w& @! J
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>/ ]  e  @( z) Q6 F
<>  </P>! ~# M7 l1 `" \9 \) v% D% _
<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>
- b, Z  `/ Y  O" N5 l! w6 V<>  </P>; i2 A' Y  s8 v1 Z
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
7 ~* Q4 P) M2 y, j) v) J<P>  </P>: v$ X& \/ e! |8 H6 b5 C
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>& w3 B5 z1 T% x! a" w8 s! S
<P>Button1Click()函数中加入如下代码: </P>6 A- j" g& @- S5 F2 N6 |! ]
<P>   Variant ex,newxls; </P>0 S! j- d6 b! k' T, c
<P>   int i,j=1; </P>9 e( [! W2 B% U* z( r  h5 S
<P>try </P>
' X% v# s1 Q2 I8 }<P>{ </P>  O1 S7 I; S0 r: E
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>, L- Y$ [" ~$ K, z* j; z3 X
<P>} </P>* i8 @. k/ @& S# P$ ?6 s7 y1 N
<P>catch(...) </P>
1 V' k7 s% I# Z. R% f& `% S7 M" ~$ U0 }<P>{ </P># m* c1 I0 a" ]; ?! w$ z
<P>ShowMessage(″无法启动Excel″); </P>
5 q  H8 X5 c0 w6 ?/ W2 o+ I8 |<P>} </P>$ v9 Y& ?& u: y
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
. b( _1 v2 m2 f+ {4 ^<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>
1 F# V9 y+ X' p2 `6 z<P>  </P>
+ S/ O' e, v- H, J) J, r<P>Table1-〉Active=true;   </P>; x( h1 \. c- l( W1 J2 Z
<P>  //打开数据库 </P>/ d6 D9 r8 E% K$ [5 D9 D
<P>Table1-〉First(); </P>8 k: u) O; j" G" R9 ?! s  T
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>- H* B$ U! H  E/ F5 g8 S4 B
<P>  //将字段名写到工作薄的第一行 </P>
/ S( L5 u0 ]  Y+ j6 A! P/ G<P>{ </P>+ o, V" G/ F' D, q0 e+ H+ V6 |2 Q, `
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>- t5 J4 c: X" Y; @( Z8 p* b
<P>  </P>
! `3 p& m" K: h<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>
5 ~: V( Q% G  Q8 f2 W& K! Q5 ^<P>} </P>
& u( x4 y$ t8 n/ N$ ]# s<P>while(!Table1-〉Eof) </P>, }, K& F( I. [( b7 \; k7 Q4 O
<P>  //将数据库中的记录依次写到工作薄中 </P>$ r  Q9 ?5 \( F3 P& e& A3 \
<P>{ </P>
, u/ j9 _0 O! T& G, F% u<P>j=j+1; </P>$ q* ]$ A, @/ W& i" w8 T1 b
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>$ L- w0 C2 L9 T; \. g
<P>{ </P>
/ Z. y  k5 g. d# O+ O4 }<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
; A, \  T5 O8 c2 m<P>(i+1), </P>% F; a2 z" g' {/ `* k
<P>  (Variant)Table1-〉Fields-〉AsString); </P>
7 w/ o8 f& X% l<P>} </P>2 J) m3 I5 L; j9 K; P
<P>Table1-〉Next(); </P>  ]  h1 L5 j( W- y/ m, [* D0 N
<P>} </P>! A0 e& l% U& _. S2 b, M
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>  N  b' [: Q0 [! U) `
<P>  //保存工作薄,filename是工作薄的全文件名 </P>
' I( F( p& ^% [0 ~9 R+ N& f<P>ex.OleFunction(″Quit″); </P>
9 C: C  @' A, n8 n+ ^& Z<P>  //退出Excel,释放OLE对象 </P>
* w1 y4 }6 V# S' f/ f* o9 w) {<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
) `: Y" u- h* k! p- @! H; e<P>include ″ComObj.hpp″。 </P>* U8 ]* m7 c  L0 l2 Z8 \; ]7 l- o
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
/ {* J" s$ |7 R% @+ Y- O9 A4 \<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>: o: N! y& P/ G) _5 i7 ]3 y- k" m
<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, 2025-7-8 12:10 , Processed in 0.528963 second(s), 55 queries .

回顶部