当前位置: 网学 > 编程文档 > DELPHI > 正文

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

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 13/07/31

鉴于大家对DELPHI十分关注,我们编辑小组在此为大家搜集整理了“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.delete;Olecon.oleobject.application.columns.delete;Olecon.oleobject.application.rows.insert;Olecon.oleobject.application.columns.insert;复制指定区域:Olecon.oleobject.application.range[‘A1:C3’].copy;从指定单元格开始粘贴:Olecon.oleobject.application.range[‘A4’].PasteSpecial;常用的就这些了,对delphi中server面板下的EXEL控件和创建EXCEL.Application COM对象的方式都适用。

  • 上一篇资讯: [DELPHI]
  • 下一篇资讯: Delphi接口详述
  • 网学推荐

    免费论文

    原创论文

    浏览:
    设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
    版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
    湘ICP备09003080号