数学建模社区-数学中国

标题: c++builder如何和excel交换数据? [打印本页]

作者: 韩冰    时间: 2005-1-26 01:22
标题: c++builder如何和excel交换数据?
<>c++builder如何和excel交换数据?</P># R0 j/ L8 P2 E. O* F" F
<>  </P>- Y/ Y: P7 O3 v4 o4 E
<>这是从网上下载的: </P>
6 b- w  y* `1 V# D9 v9 u- r3 C  h<>Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数 </P>
6 [+ y* n2 [6 b: ~/ [+ h<>  </P>
. t  W& \' ]( [4 s& X# v<>据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增 </P>6 F) M3 U: f, v3 f8 M
<>  </P>
" Z! q* U- I, x0 _+ p1 p( x  D<>加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。 </P>
# E! \$ O$ z& o/ \: N" a. S<>  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制 </P>
/ [3 I* ~+ Y" ]1 W) c4 y3 X# {% {8 F; B<>  </P>" m9 {! D1 |  H% v
<>使得开发人员在应用程序中就能调用Excel,实现数据交换。 </P>4 x( F( a6 a8 o! u9 L4 d9 w5 g6 I
<>  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该 </P>7 v8 f& L7 o- W1 c4 f7 z
<>  </P>
" C' U9 k2 d! O" M. T<>对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来 </P>: E; k: h7 r; q. j+ c6 G
<>  </P>, o* \3 j) |2 J' L# t& m$ p. y9 @( b
<>建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用 </P>
# k& Y/ ^& N  T: O<>OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName, </P># O+ ?! B6 Z- ~9 {
<>[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。 </P>. X4 S/ s. {1 [& p) H# r; B
<>  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于 </P>
( K- s2 w1 I5 |/ B5 W<>  </P>' X. T5 G$ Z" c! r+ j$ ]5 u
<>Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件 </P>& T, o/ a/ X* ^
<>  </P>
, F1 D) M8 `' e2 s8 e2 Y<>中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明 </P>
" k. v/ E( `1 ?: d( w3 W<>  </P>- I, I' s0 R; o# U  k$ i
<>C++ Builder操纵Excel的具体方法。 </P>
% ^* B& f; @8 X, Y( D: R, U1 W<>  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。 </P>
# w4 b6 _* |9 ^<>  </P>
" N: {7 `) A/ d. n0 E: w<>然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设 </P>
1 j. J2 \0 j* h* Y% G) z! C<>  </P>1 B1 O% C- w& f$ Q/ P) e
<>为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其 </P>
. u; Y% @; K( [) c0 ]7 B6 I<P>  </P>6 t5 S* s+ w) C8 g; g- ^
<P>Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在 </P>
2 }0 T- O5 c! n( ^" Z( Z5 F<P>Button1Click()函数中加入如下代码: </P>
2 q1 g3 Q6 U" f<P>   Variant ex,newxls; </P>
, O. a9 C  U4 d3 y9 r<P>   int i,j=1; </P>
) n% u5 u& [* K/ L* e& ]" N<P>try </P>: |$ s1 g" w0 U4 K* x% v' @0 x
<P>{ </P>
- O. Z# |, I& d" G; i<P>ex=CreateOleObject(″Excel.Application″); //启动Excel </P>
8 q6 f4 f& F' D( A& _! B) a<P>} </P>) Y: _% s0 E, N) q. f6 J& O
<P>catch(...) </P>5 i. |3 [: u/ s4 H! s5 \' u% G& h& y
<P>{ </P>, l( h! s. s: r' m/ p) C
<P>ShowMessage(″无法启动Excel″); </P>5 E) ]5 Q' p6 G+ [7 Z
<P>} </P>% F' V0 a. l+ E/ ~6 [3 J
<P>   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见 </P>7 y) Z6 P+ l/ v( v2 z  F3 {! Z. x& O( Z5 P
<P>newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄 </P>: d1 P8 e/ g+ Z, ^5 s
<P>  </P>& J6 W, T$ ^' Q) A% B8 P
<P>Table1-〉Active=true;   </P>; h  |. h* i5 Y
<P>  //打开数据库 </P>( W' m, c. B$ M
<P>Table1-〉First(); </P>& }) ^. U' x$ E" I  t7 Z5 P
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>* R8 X& W2 }! [% x
<P>  //将字段名写到工作薄的第一行 </P>
* C7 w1 T4 t3 v5 I. x<P>{ </P>
. N. M1 R9 u( n8 |6 |9 L<P>(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+ </P>
- @2 z& w  W8 z% g' k4 S<P>  </P>% [9 B) g0 h$ N* Z5 K4 z: z
<P>1),(Variant)Table1-〉Fields-〉FieldName); </P>
0 O5 b' Y2 Y5 V7 ~<P>} </P>' E+ P+ k0 L( D) n, S
<P>while(!Table1-〉Eof) </P>; u5 T# o* q2 i+ r: {7 O
<P>  //将数据库中的记录依次写到工作薄中 </P>. ]! s. k8 h7 u
<P>{ </P>5 ~7 ~! d" [+ u7 V1 T; `
<P>j=j+1; </P>8 p3 S) q* t/ m9 c+ i( }
<P>for(i=0;i〈Table1-〉FieldCount;i++) </P>; h  \6 U: K8 _8 d# \6 [- p# t" P
<P>{ </P>$ y* y" S0 Y, Y- g1 u
<P>  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant) </P>
  N. n6 Z  j# W4 `0 y$ \<P>(i+1), </P>2 l/ V" b% x/ A: _# [' g
<P>  (Variant)Table1-〉Fields-〉AsString); </P>  j8 ~9 ^3 P% f/ ^
<P>} </P>+ ~/ g* M7 X5 m+ l" @
<P>Table1-〉Next(); </P>
; l& {8 n$ W/ K  p0 h/ F<P>} </P>$ x" ]" z1 p, W/ B! j1 X
<P>newxls.OleFunction(″SaveAs″,(Variant)filename); </P>; D& o/ _" }8 M% B; ~' z
<P>  //保存工作薄,filename是工作薄的全文件名 </P>  d3 i+ o. r" Q- s5 L, n# `! W; E
<P>ex.OleFunction(″Quit″); </P>$ i; |( p, E0 u$ R+ x! T6 J& ^; E
<P>  //退出Excel,释放OLE对象 </P>" n* L' z' b3 K$ {8 n! S+ G
<P>  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上# </P>  M/ k! j+ {! G1 S5 g/ a' j
<P>include ″ComObj.hpp″。 </P>3 w# `5 P# R4 B- R' N/ {+ g  }
<P>  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用 </P>) O8 v! C& g- N  P0 M
<P>OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。 </P>
% t$ E6 c- m& L+ z$ d! e<P>  以上代码在Windows 98操作系统、C++ Builder 3.0下调试运行通过。 </P>
作者: liunengwu    时间: 2010-4-8 14:07
体力 已经不充沛啦!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5