社区
Windows SDK/API
帖子详情
delphi: OleContainer显示excel表格,如何实现、修改提示、保存、打印预览、打印等?
天鸽
2009-11-06 04:29:41
OleContainer显示excel表格,如何实现、修改提示、保存、打印预览、打印等?
如何通过程序修改excel表
...全文
1966
10
打赏
收藏
delphi: OleContainer显示excel表格,如何实现、修改提示、保存、打印预览、打印等?
OleContainer显示excel表格,如何实现、修改提示、保存、打印预览、打印等? 如何通过程序修改excel表
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
10 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
foodztf
2010-05-10
打赏
举报
回复
[Quote=引用 7 楼 iseekcode 的回复:]
试试下面的代码:
var excel:Variant;
excel:=GetActiveOleObject('Excel.Application');
if not excel.ActiveWorkBook.Saved then excel.ActiveWorkBook.Save;
[/Quote] 高手
hjkto
2009-11-21
打赏
举报
回复
mark
pigwi
2009-11-21
打赏
举报
回复
OleContainer1.SaveAsDocument('filename'); //保存
iseekcode
2009-11-13
打赏
举报
回复
试试下面的代码:
var excel:Variant;
excel:=GetActiveOleObject('Excel.Application');
if not excel.ActiveWorkBook.Saved then excel.ActiveWorkBook.Save;
天鸽
2009-11-13
打赏
举报
回复
保存时出错:
被呼叫方拒绝接收呼叫!
要怎么解决????
风之谷
2009-11-09
打赏
举报
回复
olecontainer1.oleobject.application.ativeWorkBOok.saveas(filename);
filename与你存在的文件名称一样
天鸽
2009-11-09
打赏
举报
回复
等待.........................
天鸽
2009-11-06
打赏
举报
回复
保存
保存
保存
保存????
天鸽
2009-11-06
打赏
举报
回复
在 OleContainer 中修改了excel表,如何将修改内容保存到这张表呢?
OleContainer1.close;
OleContainer1.AllowActiveDoc:=false;
OleContainer1.AllowInPlace:=false;
OleContainer1.DoVerb(1);
OleContainer1.OleObject.Application.visible:=true;
olecontainer1.oleobject.application.ativeWorkBOok.save();
根本没有作用??????????
kampan
2009-11-06
打赏
举报
回复
引用:
Delphi控制Excel的重要属性和方法
在delphi中调用excel有四种方式,我们选取其中的一种用OleObject来装载excel工作表的方式来谈delphi控制excel的重要属性和方法。
首先给出通过OLE创建的一些主要代码步进行简单说明:
创建OLE对象:
Var olecon: TOleContainer;
Olecon:= TOleContainer.Create(self);
Olecon.oleobject:= Olecon.CreateObject('excel.sheet',false);
或选择导入一个excel文件来创建OLE对象:
Olecon.oleobject:= Olecon.CreateObjectFromFile(xlsname,false);
最好隐藏excel的几个工具条,这样就好象是嵌在你的程序中的一个表而已了:
Olecon.OleObject.application.CommandBars['Standard'].Visible:=false;
Olecon.OleObject.application.CommandBars['Formatting'].Visible:=false;
Olecon.OleObject.application.CommandBars['Reviewing'].Visible:=false;
然后显示并激活excel表,对TOleContainer定义的对象:
Olecon.show;
Olecon.doverb(0);
这样基本可以了,但TOleContainer有个不好的地方,就是当你一点击其它控件是就它就失去焦点,然后就自动退出,其实并没有真的退出,只是需要你再次激活它而已,关键是当它失去焦点的时候就excel对象就不见了,可以用Timage控件把TOleContainer所在的地方有EXCEL时候的区域图片截下来骗骗用户,我们这里主要不是讲这个,就不详述了。
下面我们就开始讲Excel_TLB中的接口的常用属性和方法,主要是针对导出和设定报表格式的一些接口元素。
单元格的读写属性:
olecon.OleObject.application.cells.item[1,1];
olecon.OleObject.application.cells(1,1);
olecon.OleObject.application.cells[1,1].Value;
上面三种都可以对工作表的‘A1’单元进行读写。
在delphi中对单元格(集),区域,工作表等所有对象的操作都是要Variant来实现的。
自己的程序中选定区域赋给Range:
Var range,sheet:Variant;
Range:= olecon.OleObject.application.Range['A1:C3'];
或者:
Sheet:= olecon.OleObject.application.Activesheet;
Range:= olecon.OleObject.application.Range[sheet.cells[1,1],sheet.cells[3,3]];
对上面的Range合并单元格:
Range.merge;
Range. FormulaR1C1:=’合并区’;//合并后写入文本
注意以后要读合并的单元格里面的文本就是读合并区域的左上角的那个单元格的文本
在excel表中选定区域赋给range:
range:=excel_grid1.OleObject.application.selection;
拆分单元格:
Range.unmerge;
合并后设定单元格(集)的格式:
Range.HorizontalAlignment:= xlCenter;// 文本水平居中方式
Range.VerticalAlignment:= xlCenter//文本垂直居中方式
Range.WrapText:=true;//文本自动换行
Range.Borders.LineStyle:=1//加边框
Range.Interior.ColorIndex:=39;//填充颜色为淡紫色
Range.Font.name:=’ 隶书’;//字体
Range.Font.Color:=clBlue;//字体颜色
常用格式也就这些,以上这些对于单个单元格也适用。
在excel表中寻找前后上下的单元格:
Var u1,u2,u3,u4,u5:Variant;
U1:=olecon.oleobject.application.activecell;//获取当前格;
U2:=u1.previous;//非特殊情况就是u1左边的一格;
U3:=ui.next;//非特殊情况就是u2右边的一格;
U4:=olecon.oleobject.application.cells[u1.cells.row-1,u1.cells.column];//非特殊情况为上面一格
U5:=olecon.oleobject.application.cells[u1.cells.row+1,u1.cells.column];//非特殊情况为下面一格
删除和插入一行和一列:
Olecon.oleobject.application.rows[2].delete;
Olecon.oleobject.application.columns[2].delete;
Olecon.oleobject.application.rows[2].insert;
Olecon.oleobject.application.columns[2].insert;
复制指定区域:
Olecon.oleobject.application.range[‘A1:C3’].copy;
从指定单元格开始粘贴:
Olecon.oleobject.application.range[‘A4’].PasteSpecial;
常用的就这些了,对delphi中server面板下的EXEL控件和创建EXCEL.Application COM对象的方式都适用。
Delphi
与Ole,Word,
Excel
,查找与替换等
前面我就
Delphi
中调用Word写了一些,比较注重于具体
实现
,对于研究的方法则说的比较片面。 今天晚上,我静下心来,总结了一下怎样在
Delphi
中生成操作Word的代码。如果说前面我写的 是金子,那么下面这篇文章就是...
Delphi
的OFFICE开发[转]
通常我们要设计出很多各种格式的文档、报表,经常要进行文件的创建、编辑及
修改
,虽然
delphi
本身提供了很多设计报表的控件或方法,但是存在明显的不足,比如中文输入,数据格式的控制等操作起来比较麻烦。...
Delphi
和Office
通常我们要设计出很多各种格式的文档、报表,经常要进行文件的创建、编辑及
修改
,虽然
Delphi
本身提供了很多设计报表的控件或方法,但是存在明显的不足,比如中文输入,数据格式的控制等操作起来比较麻烦。...
Delphi
和Office程序开发
通常我们要设计出很多各种格式的文档、报表,经常要进行文件的创建、编辑及
修改
,虽然
delphi
本身提供了很多设计报表的控件或方法,但是存在明显的不足,比如中文输入,数据格式的控制等操作起来比较麻烦。...
Delphi
与Word之间的融合技术
问题:
Delphi
与Word之间的融合技术 ( 积分:0, 回复:325, 阅读:37835 )分类:OLE/Automation ( 版主:g622, satanmonkey ) 来自:yzhshi, 时间:2001-11-18 17:52:00, ID:737517[
显示
:小字体 | 大字体] <tools:...
Windows SDK/API
1,183
社区成员
22,335
社区内容
发帖
与我相关
我的任务
Windows SDK/API
Delphi Windows SDK/API
复制链接
扫一扫
分享
社区描述
Delphi Windows SDK/API
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章