请问如何把excel嵌入到程序里面,可以对其编辑保存等等,如同在浏览器里面打开excel文件一样,如何实现?

zb981078 2003-09-30 10:02:44
如题!小弟在此学习!200分!!!因为我给分的上限是100,这个揭帖后在送上另外的100分!!!
...全文
159 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
canjian 2003-10-05
  • 打赏
  • 举报
回复
有同样的需求
study
blankman 2003-10-03
  • 打赏
  • 举报
回复
study
xizhouhawk 2003-10-01
  • 打赏
  • 举报
回复
就用ole可以了,我这里只有word的例子,如果你要的话,发信息给我
zb981078 2003-09-30
  • 打赏
  • 举报
回复
请大家稍微贴上一些代码,当然不可能完全像excel,仅仅能够像一部分就可以了!
ljianq 2003-09-30
  • 打赏
  • 举报
回复
在BCB的Examples目录下有例子。
编译失败 2003-09-30
  • 打赏
  • 举报
回复
完全像Excel不大可能,試想一下,MS也不會讓你那麽做,你可以用別的代替,比如ActiveX下的F1Book控件
ljianq 2003-09-30
  • 打赏
  • 举报
回复
OleContainer可以。
ccrun.com 2003-09-30
  • 打赏
  • 举报
回复
试试OleContainer
7rainbow 2003-09-30
  • 打赏
  • 举报
回复
你可以参考一下Examples目录的例程
7rainbow 2003-09-30
  • 打赏
  • 举报
回复
用OleContainer。
zb981078 2003-09-30
  • 打赏
  • 举报
回复
上面这位老兄误会我的意思了,是excel的嵌入式操作,像在浏览器里面打开一个excel文件一样,要求是嵌入式的。如果不是嵌入式的,我是知道如何作的
tigerhohoo 2003-09-30
  • 打赏
  • 举报
回复
用C++Builder操纵Excel

Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。

  C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制使得开发人员在应用程序中就能调用Excel,实现数据交换。

  在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName,[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。

  C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明C++ Builder操纵Excel的具体方法。

  首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在Button1Click()函数中加入如下代码:

   Variant ex,newxls;

   int i,j=1;

try

{

ex=CreateOleObject(″Excel.Application″); //启动Excel

}

catch(...)

{

ShowMessage(″无法启动Excel″);

}

   ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见

newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);//新建一个工作薄

Table1-〉Active=true;  

  //打开数据库

Table1-〉First();

for(i=0;i〈Table1-〉FieldCount;i++)

  //将字段名写到工作薄的第一行

{

(ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,(Variant)(i+1),(Variant)Table1-〉Fields[i]-〉FieldName);

}

while(!Table1-〉Eof)

  //将数据库中的记录依次写到工作薄中

{

j=j+1;

for(i=0;i〈Table1-〉FieldCount;i++)

{

  (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)j,(Variant)(i+1),

  (Variant)Table1-〉Fields[i]-〉AsString);

}

Table1-〉Next();

}

newxls.OleFunction(″SaveAs″,(Variant)filename);

  //保存工作薄,filename是工作薄的全文件名

ex.OleFunction(″Quit″);

  //退出Excel,释放OLE对象

  注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上#include ″ComObj.hpp″。

  运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。

  以上代码在Windows 98操作系统、C++ Builder 3.0下调试运行通过。

  摘自《赛迪网》 赵天平/文

13,825

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder相关内容讨论区
社区管理员
  • 基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧