QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>% @1 L& {9 F  d4 u: g. U
<>  </P>
* m8 v/ S4 C  E8 P<>这是从网上下载的: </P>: [6 a0 S2 x* j' _  Q8 L3 j
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
; A: c1 g) N# S5 H<>  </P>/ x4 |: h: e1 ~+ Z  c
<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
5 u2 _$ Y9 P9 G5 n: Y3 \  K<>  </P>
3 q1 g/ f: D  t: [) L% j5 \<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>! J5 Z/ j/ G9 P1 j+ m# }/ d; U" W% S
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>, Q7 b8 u' p( S7 a, u
<>  </P>+ w# q1 y+ E! b! p+ S& _
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>
0 t* P" g1 i$ i8 z* R* z" x( A  ?<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>
( t! m7 N& r+ N& t( t<>  </P>8 _* D+ g1 `4 Y3 ?
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
" \3 w2 k- x/ u* Y+ L<>  </P>& n0 P: s( f; t: R2 A; U4 y- A  {
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>: d& i! ?4 u7 Q+ x. t% P
<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
/ w: N2 L( a. E! H* v! Q<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
, p: X( e  z1 D+ a0 y$ m<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
8 n# P* V! I6 ?* k<>  </P>
1 X- n8 n7 y/ [5 c7 g( l1 \. u! C5 V( ~<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>% K9 V: O% ~. s
<>  </P>! A$ l( l" _3 r6 o) R
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>
! B: U' C" M5 _( F7 B% s<>  </P>2 r, D6 v0 V, O2 w4 T! k4 K3 J
<>C++ Builder操纵Excel的具体方法。 </P>$ v! ~# f! X3 t* W+ E
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
9 H) {1 }% |* ?0 b1 b* a<>  </P>
5 {0 I5 n6 l0 o$ @! G' h<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>8 ?- ?. e* {1 E" ^  A0 n. o/ V" [
<>  </P>. K3 J. v& W' o2 O/ B
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
" H" O: e$ W* O& q" {8 s+ T) }<P>  </P>
- m3 D, j: C0 k+ G! U<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>) W$ Q; x$ a; I
<P>Button1Click()函数中加入如下代码: </P>
$ ]5 c5 \9 g& k1 ?# x6 m<P>   Variant ex,newxls; </P>/ k! t' r, j' `5 F& J2 _
<P>   int i,j=1; </P>
! ]+ @" i* o$ F9 j) A<P>try </P>
/ e3 Z  ^% E2 F  e<P>{ </P>% ]$ |* d& d: J; g! c& t$ y
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
7 L1 d" P+ p$ T% u1 g# ?<P>} </P>
# U$ f. R8 y$ ?  \<P>catch(...) </P>
! e  Y4 Y, \5 c* w6 E" c$ e<P>{ </P>! p8 J( c8 w7 B5 s* k; _- |. a
<P>ShowMessage(″无法启动Excel″); </P>
4 b( z6 h1 t% T. J' }! @7 P% e/ N<P>} </P>
( J5 v/ n4 |' B) p% N2 R; j* T<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>
* Y8 m0 b4 v2 Z/ X9 x( t& Y<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>' c: h1 b* b* {+ A; m* s& n" ?
<P>  </P>
6 h# }2 l* H- U<P>Table1-〉Active=true;   </P>) x$ N" L9 c2 C  l
<P>  //打开数据库 </P>
/ R4 O3 T  E4 D" q" a1 L! _<P>Table1-〉First(); </P>
7 p) X; w# C% `( c3 Y# k<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
) I( \$ J8 w9 k% o0 Z' R<P>  //将字段名写到工作薄的第一行 </P>
8 q+ u' i9 d/ ^7 I$ ?0 O<P>{ </P>
, W1 |# e1 B! K' ], i<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
# ?$ l3 g/ w9 y& g: D- ^1 ~, b' M<P>  </P>
$ V" a/ ]6 \. W& A<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>. x9 Y, o0 H" B( F; Q
<P>} </P>7 B2 N7 o+ K+ }/ d# l4 p5 z2 _
<P>while(!Table1-〉Eof) </P>0 ]2 d9 a! z0 M' z$ p* _" I; @
<P>  //将数据库中的记录依次写到工作薄中 </P>
) \' U. b7 B+ @, R; o3 L& o+ Q( W: r<P>{ </P>/ L3 b- K8 e0 X
<P>j=j+1; </P>* H) ~* Z, k: W  u. L, V$ o
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>0 g4 d( V; n7 C
<P>{ </P>
; y" x1 ^9 R. s5 }* ~. ?<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
9 @8 L( D  T$ \% e<P>(i+1), </P>
" Q+ v4 R; [& d/ [6 ]* Y+ C<P>  (Variant)Table1-〉Fields-〉AsString); </P>
9 z' N+ O; v" k8 b) _<P>} </P>8 F* m) |  P* L
<P>Table1-〉Next(); </P>
! i  |% \% Q' F<P>} </P>
% n& k  k2 k' s<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
: N" s2 \1 ]" ?7 l2 `$ b2 a<P>  //保存工作薄,filename是工作薄的全文件名 </P>0 f/ X4 E, w5 b* Y
<P>ex.OleFunction(″Quit″); </P>
3 w) B5 {, [8 q- C4 V. I6 Q8 E. r<P>  //退出Excel,释放OLE对象 </P>
$ i$ t5 T+ Z) |/ k<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
  g! @; l& }, T1 }8 R7 f2 H<P>include ″ComObj.hpp″。 </P>
8 ]8 N2 @, q9 n$ [7 y/ ]5 Z5 {, R<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>' K9 H; [5 ^5 T/ w7 h& K7 a! `; E
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
$ Y' F5 O* w& Y, v  X: g9 O' m<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-6-13 09:03 , Processed in 0.457216 second(s), 64 queries .

回顶部