QQ登录

只需要一步,快速开始

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

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

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

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 01:22 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>c++builder如何和excel交换数据?</P>
% n% q# W4 P, F: P; H& G<>  </P>0 H2 P1 Z: ]3 z# @
<>这是从网上下载的: </P>1 ]% B  R! S. L" v
<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
0 P5 D- r2 \# T; D( y) ~1 e<>  </P>
3 Z. }1 G- v1 ]9 t% t3 Q( R<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>+ v7 E+ C& q4 C! B
<>  </P>
9 Q+ o3 H& Q& y) n$ l$ S( N& p<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>$ L( f2 C( s5 i+ s! L. A  [$ R% h
<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
/ p7 I- k4 t  J3 z- L) ^- o- H8 c<>  </P>
$ r; [& `- j+ L6 e<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>
1 A% R( t0 p" l' [3 e8 ^9 _6 O" r1 v<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>1 ]: v* L; p6 I. _/ j7 u& E
<>  </P>6 d1 o1 W. P) g
<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>' z5 |3 b; n% |$ ?) P4 V
<>  </P>
( g( x% D# f2 ]<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>7 r- \) ?1 g" H7 l
<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P>
9 Q/ O2 b$ m7 ?- q: ?: v% R<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>
' V0 }  B0 z0 B! x3 y- [<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
# @: L. Y( j( G' J! k: m* q1 D<>  </P>' B# o% f' y7 r4 z3 ?5 s7 m5 \
<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>) E) `& D, E2 h1 l& V) i
<>  </P>$ I4 `1 N2 `1 M9 g# L
<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>! l+ b0 y9 V$ ~$ |/ C
<>  </P>! w# Q* f% G: ~) L9 U# t; {
<>C++ Builder操纵Excel的具体方法。 </P>% B! t3 Q% M2 }/ E1 S5 t( Q) H
<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
# g6 l8 ~; F. [  b7 T' J* j<>  </P>
* s/ k9 d, l% S" {! v<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>9 b( A/ s& L$ I1 j
<>  </P>) n% u- d5 b/ S# Z8 u' V+ u1 J# f" x8 K6 f
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
; _. D  r/ e" G* U<P>  </P>
- `0 U  k" q9 u! ?3 J<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>. P5 F8 l6 e" R1 S
<P>Button1Click()函数中加入如下代码: </P>% `  N  P- Q- I* H
<P>   Variant ex,newxls; </P>1 p; y1 q: X3 E, E5 ]- i$ T5 \4 r
<P>   int i,j=1; </P>
! L3 X! m: n; y; c5 N<P>try </P>* J( T# i  ~) d. H
<P>{ </P>. ]4 ~4 n. V6 o# ~3 |/ t
<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
9 O, N6 n% {1 k7 v) q<P>} </P>
, ^5 \% A3 B0 D5 r<P>catch(...) </P>
; p( \6 R; F( q* K, o1 ?0 J. l+ y<P>{ </P>1 ?( C" S$ }% c
<P>ShowMessage(″无法启动Excel″); </P>/ N# s& Z* o8 p1 [
<P>} </P>
) V$ o, e( y; C2 n3 a<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>3 V0 k( D! }+ B7 T( B  \
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>
6 D( P1 K6 ^0 t3 d' [$ d7 C<P>  </P>
  y  N9 _. R' J0 f<P>Table1-〉Active=true;   </P>
! `& Q; A9 T: T! b7 F<P>  //打开数据库 </P>
* `* U+ R; l2 a- K0 b* A<P>Table1-〉First(); </P>
- F! [7 N9 U( p<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>% S: D0 K% _6 ?3 c/ E; \, _6 b0 J
<P>  //将字段名写到工作薄的第一行 </P>
. U: Y. H, {, ]3 e( ^9 Z<P>{ </P>
2 \) W# e9 G6 R8 j- ?! I<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
  @7 J! @1 x; r5 Z- Q- n' `/ r. h2 H<P>  </P>
6 }. q/ e- ]1 q* H<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>) N, n6 p" q9 c; b$ a7 s% y! j7 l
<P>} </P>
/ g+ |) j1 b% n' A/ B+ W  j0 J<P>while(!Table1-〉Eof) </P>
8 ~; e3 r: G: e* B2 h8 H; s; B! A<P>  //将数据库中的记录依次写到工作薄中 </P>; V% A! Q$ ?; v4 N. E0 f( A5 Y
<P>{ </P>9 f4 C, a) o) E- a" F: q* d  P
<P>j=j+1; </P>3 E. M  I$ ]5 ~" e
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>9 I* {  a: }2 Y. s+ h) W: l/ P" D
<P>{ </P>
6 U, S  W3 Y! p( ^( ?+ k<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P># T9 l- c5 c! S  n  Q* t
<P>(i+1), </P>! n2 q1 n# E: D3 r9 ^
<P>  (Variant)Table1-〉Fields-〉AsString); </P>
2 B$ C( X" \: d4 Q2 v<P>} </P>" d  j  _! z" Z) I
<P>Table1-〉Next(); </P>
& u" d2 g( `0 F: ]' b<P>} </P>2 W3 V# [$ I" f& y- d& l. X  o
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>/ ~! d6 i6 x# C, J6 w8 P1 R
<P>  //保存工作薄,filename是工作薄的全文件名 </P>5 I7 s4 y1 [7 w" _) p7 M. U+ b
<P>ex.OleFunction(″Quit″); </P>3 P0 p" e7 T% f$ {1 F" G- X- y
<P>  //退出Excel,释放OLE对象 </P>& k! w3 Y3 m% N, y) w" p
<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>
# E  ?2 k; u/ z- e<P>include ″ComObj.hpp″。 </P>( k  l6 _, o: v: q
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>/ ?4 I. R1 g5 y* B3 ?( y
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
3 D5 N, q8 f8 q9 R; c& X4 j0 G<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-4-19 00:44 , Processed in 0.450702 second(s), 64 queries .

回顶部