网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Delphi
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.制作从屏幕右下角逐渐弹出的消息.
.一个从EXE、DLL文件中提取、存取.
.Linux的开发利器,Kylix.
.温和的关闭连接.
.移动没有CAPTION的窗体.
.流的解压及压缩(代码精简高效).
.delphi中的字符串处理,以及几个.
.用Delphi编写CGI程序(一).
.剪贴板的流存储.
.注册机制.
.Delphi多层开发方案比较.
.Delphi中关于TApplication类的详.
.生成GBK码表.
.关于在COM中使用可选参数的研究.
.利用Delphi编写Windows外壳扩展.
.Delphi编程实现Ping操作.
.检测Delphi是否正在运行.
.如何获取自己在程序中运行的外部.
.如何在Delphi中实现ASP编程.
.D7下的只能输入数字的控件(类似.

Delphi控制Excel的重要属性和方法

发表日期:2006-2-4


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;

常用的就这些了,对delphiserver面板下的EXEL控件和创建EXCEL.Application COM对象的方式都适用。

 

                                                    作者:费亚

                                                    时间:2004-9-14

上一篇:使用TImage浏览与保存网络图像 人气:5242
下一篇:Delphi的接口陷阱 人气:4494
浏览全部Delphi的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐