QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>/ \  h/ C1 h* i4 ^& Z* q! k
<>  </P>
# m4 I# ^# M, F0 r+ X<>这是从网上下载的: </P>
$ ?+ T5 l" n' T% @+ a8 D<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
8 w5 L8 u! Q5 _# e  u  C4 d5 a2 g<>  </P>5 i% d7 R% a9 ?- E
<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
3 p1 g- D: \6 H+ F( X( u  R! q- r<>  </P>
' {+ u" F6 p9 A<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>4 d: u+ w  V3 b6 a) v1 |9 T
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
0 J0 m' V  @3 `( T+ h# b8 K0 @6 D<>  </P>5 {9 K' o4 V' Y- w
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>* A1 Z5 ^% n) e( h* P+ |
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>1 ]! h, E( u3 s) R. j
<>  </P>% q: b! k$ E, p
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>
+ ?8 P$ K2 J- ~<>  </P>. g. Z% K+ [) p
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
$ M# ]5 M  t; ?- e( G0 w8 w: w  P<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
8 B- X  c' F# x7 x: t5 E<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>6 _& u  t9 M4 F0 h! H3 |! B
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>& N6 ]2 ?* y% ]) X2 z9 w( R
<>  </P>1 t+ s$ x2 U- }: p# K- \$ i2 S6 U
<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
3 Z) N' x( Z8 j" v9 m- N9 L9 \<>  </P>
) ^) O+ j, o- X& d<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>. L) o5 k: `3 ^) P
<>  </P>+ c3 @4 c7 G* `% y
<>C++ Builder操纵Excel的具体方法。 </P>
( A; `) A! V* p# ^2 \$ ]<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>( V& c  U( o! f& P# L! A8 E$ \
<>  </P>0 A" U5 f, J+ D; R. q& \) S6 H
<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>6 y/ Z; F1 }* W/ o( g( D- X9 f
<>  </P>
3 c+ H3 L2 {3 |; s8 c<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>5 G6 `; h1 k; n* M$ D, ^
<P>  </P>/ j/ l) d0 x6 e4 P8 l
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>- F2 D0 F! V( S) m+ k4 y
<P>Button1Click()函数中加入如下代码: </P>
' \. {" R8 {% f, j* Q1 `<P>   Variant ex,newxls; </P>6 ]$ X" W+ f4 K8 J# s' r4 w3 k
<P>   int i,j=1; </P>! }5 ]! J3 F9 P0 Q6 y0 I9 O, ?
<P>try </P>1 @$ w8 Y5 x. {  R
<P>{ </P>6 u* M8 j  t% B' s6 e- O4 [
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>. ?, q& {- a" I8 f# {
<P>} </P>1 `: \# o6 {: y6 m- g
<P>catch(...) </P>
% s6 A2 Z% b" d0 |/ m/ z% |, Y<P>{ </P>
; w% [1 d. e4 V, |<P>ShowMessage(″无法启动Excel″); </P>9 X, A/ v, B2 B: ], L1 T
<P>} </P>! V8 ~- Z0 M2 Y1 ?- Q6 U: x
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>1 S+ ?+ }, k0 @/ p4 r9 u$ e) _
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>
2 ~2 |$ ^& k' g- W) l/ H( F. p4 x$ I1 W<P>  </P>+ m; R6 w( A3 Q/ B) U4 e4 M- I
<P>Table1-〉Active=true;   </P>
# c6 f# g) v, f0 O+ b1 c2 X<P>  //打开数据库 </P>
% Q$ U. ]- m, s% b! X5 \5 e  P<P>Table1-〉First(); </P>
$ ~4 E! `' j7 W4 U<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>
6 C3 _7 [3 d* g  Y( A<P>  //将字段名写到工作薄的第一行 </P>
1 @8 B3 r+ W! u' k<P>{ </P>  H7 [7 S( H9 t/ ]( Y) k% @3 T
<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
% A4 Y9 m5 `, p6 y<P>  </P>% Z5 |. F. W& F
<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>" {: Z3 f! _3 h6 `) u
<P>} </P>
6 }4 \9 Z- N2 M2 K' _4 G3 [<P>while(!Table1-〉Eof) </P>  X" B) c" B; O. Z" G! t( @
<P>  //将数据库中的记录依次写到工作薄中 </P>3 D) C7 u# ?* o5 L% a
<P>{ </P>- j( G0 @# l6 N& m6 O8 \" \4 H
<P>j=j+1; </P>+ M4 Q( s0 e0 T) f4 T6 F, m
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>8 z% B/ G/ z8 y1 ^. `/ W
<P>{ </P>  J. ^1 U5 p4 X+ E/ v
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
; w  C7 W8 I: P3 k<P>(i+1), </P>
0 M7 N$ f1 ~1 B6 V- i/ ]! L<P>  (Variant)Table1-〉Fields-〉AsString); </P>
; k% G/ _. {/ g; m: i! i: f$ c<P>} </P>
0 ?) N: ]" ?( V<P>Table1-〉Next(); </P>: a5 W% ~3 i! \. _4 j  e
<P>} </P>; h- M% h7 v. {
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>
+ l+ S9 [) R" E<P>  //保存工作薄,filename是工作薄的全文件名 </P>
. K; M/ s7 n5 U% s7 [<P>ex.OleFunction(″Quit″); </P>- w. U; |( `3 i
<P>  //退出Excel,释放OLE对象 </P>: N. w! z, {( M" b, V5 g) L
<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
6 {5 q; |& N4 V. @, v<P>include ″ComObj.hpp″。 </P>2 n/ l+ J/ Q: _3 R: t! e$ e
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>6 {# K$ ~9 @8 Z0 j2 V
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
7 A: x6 g4 f" r* 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-9-17 13:41 , Processed in 0.408966 second(s), 63 queries .

回顶部