QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>5 m4 \0 K& S; c) t0 d
<>  </P>4 k" S# Q; ~& b6 _! U; W1 k
<>这是从网上下载的: </P>/ r8 S1 z9 W4 R
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>9 ~% m2 v0 I1 @% p
<>  </P>5 C6 g, A# |  O7 L1 k. L
<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>
+ X  z; J4 K0 u$ D/ J3 F<>  </P>4 ~$ u( U1 b. Y
<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>
' g+ }; D. D6 y; b9 d, z2 R. }<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
. u( e& h  B, ~8 D0 k<>  </P>
, G* h4 j3 f! M  e<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>6 K. @; }& m2 T
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>
$ H* w% z% F/ w! D, x8 g<>  </P>
7 R2 x- k& w9 a# R<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>+ V* a3 c* q. h, d8 D& F. k2 ]
<>  </P>
( T9 d) t* w0 u* E& _0 g<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
# M: F( b$ h7 x2 f<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
2 K7 @8 Y/ F% z' l5 g$ q# S<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
4 n0 G4 Y2 y: F, j<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
9 F! G. L$ }# m0 I<>  </P>
7 j3 H# h# `. ]; o+ v, }& L" ^<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>
1 O  Q$ d$ v# O+ q7 k8 ^<>  </P>
+ K5 h' W8 e/ S! Z) p+ W+ C7 e# L+ `<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>' }7 ~7 [' Z5 W: \% `, G2 o
<>  </P>( ]" c. T: v/ h% H
<>C++ Builder操纵Excel的具体方法。 </P>
3 s' d9 E' s$ @( Y<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>: A2 {  [# a- m. |0 z# V6 l$ z
<>  </P>- a" N9 I1 h6 Z# M7 e- F
<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>& H7 Q. i: Y. _2 f: x0 }( b8 U
<>  </P>9 m! [# k  z* \/ [! y) Q
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>" ~$ y  G2 ?; g) |( a$ m& u* l% Q
<P>  </P>9 o# E' y* l# e% v- B
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
* q- t* _; E) N" c& I3 ?<P>Button1Click()函数中加入如下代码: </P>
6 u0 o  P* x, ^+ N5 H; B- }<P>   Variant ex,newxls; </P>* W, Y8 S9 b* ~1 N7 W: {
<P>   int i,j=1; </P>- E9 {6 O; F! `$ a, k5 c: r
<P>try </P>8 Q, m7 `" G  s& D
<P>{ </P>8 _. m( L$ j2 s: \, E
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>: U3 o8 ]% O/ p7 ~: `
<P>} </P># |! z/ X) J- u$ f0 ]4 y
<P>catch(...) </P>6 F- Q. E, Q: U4 j6 i9 S
<P>{ </P>
7 p5 C. p; F( J. O- b3 g. x<P>ShowMessage(″无法启动Excel″); </P>' T: H0 G) p5 ?; V8 F
<P>} </P>8 x# o' ~" g2 D" p9 b1 j, O7 y% O( \
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>/ ]8 ~! S3 a- N' e
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>& I: J) b- m+ {. F/ D% _, {' A
<P>  </P>. K8 U# I  X* j8 h
<P>Table1-〉Active=true;   </P>+ m( a3 z$ t  l) m
<P>  //打开数据库 </P>- q( ?# Y8 S- A) I/ E  O2 Q# _& a
<P>Table1-〉First(); </P>2 u( s% ~6 A5 R2 i) M# K/ Q3 q
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>. K5 _/ G! A1 s* a; e
<P>  //将字段名写到工作薄的第一行 </P>
% x/ G) m2 f' Z- ^# E4 ]<P>{ </P>
) {* [3 ^& h4 R- B2 B" p% b" L% B6 d<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
4 x/ Q0 ]$ T$ m3 b<P>  </P>
% ~7 N7 {! C( D) J<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>; H3 y/ O8 |! C; Y
<P>} </P># Z% m0 c7 |! z# ^: [
<P>while(!Table1-〉Eof) </P>
4 Y! I! B. r8 x3 s. b2 V<P>  //将数据库中的记录依次写到工作薄中 </P>
3 l" `3 ^: Y3 j7 T& |<P>{ </P>
5 A  c. c2 i% q<P>j=j+1; </P>* u. f- x) C9 g4 Q( G$ q8 f
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>: V% o+ L4 s! h  ]1 Z0 a; F7 ]. k
<P>{ </P>
) D+ B1 f+ F. m( T" Q: B% S$ K<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
" |( t2 j! i0 c0 s: v<P>(i+1), </P>
8 A  Z' B9 y2 {. f9 ~- _<P>  (Variant)Table1-〉Fields-〉AsString); </P>
: |5 E' O6 S- {3 |8 @8 O<P>} </P>
  _" G+ O# o6 k5 A# Z' a" c3 d<P>Table1-〉Next(); </P>
: J$ c, B( Q- I, K0 _<P>} </P>
' p% @4 Y9 E' Y* x8 @<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>/ k: l1 r2 A1 R- }- L: ]7 e9 t0 V
<P>  //保存工作薄,filename是工作薄的全文件名 </P>
2 o- Z, C1 k0 Y( O6 [+ ^# e2 Q( s<P>ex.OleFunction(″Quit″); </P>5 _0 l, T( ^- g; c/ V) n6 ~/ @2 T
<P>  //退出Excel,释放OLE对象 </P>
' V& r1 O$ I) ?/ T2 g<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
2 N( x5 r& @1 i0 X# B<P>include ″ComObj.hpp″。 </P>! a, N+ [5 X" i+ c
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>
5 \: k- v4 H8 g2 n/ Z<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
5 n/ V. F9 y9 a% p<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-6-29 05:18 , Processed in 0.693013 second(s), 55 queries .

回顶部