1.首先引用comobj、varints单元

2.声明xlApp,xlBook, xlSheet,picture: Variant;

3.基本操作

xlApp:=CreateOleObject('Excel.Application'); 有异常才没有安装Excel。

xlBook := xlApp.workBooks.Open(sd1.FileName);//打开已经存在的excel文件

//xlBook := xlApp.WorkBooks.Add;//增加工作表

xlBook.WorkSheets[1].Activate;//激活工作表

xlBook.WorkSheets[1].Cells[1,1] := '姓名';//单元格赋值

xlBook.save;//保存工作表

//xlBook.SaveAs(directory_filname);//另保存工作表

xlBook.close;

xlApp.Quit;

xlApp:= UnAssigned;

4.其他常用操作

xlApp.caption:='应用程序调用 Microsoft Excel';//

xlBook.worksheets[1].cells.NumberFormatLocal:='@';//设置工作表为文本方式

xlBook.worksheets[1].name:='sheet123';//工作表的名字

xlBook.worksheets[1].rows[1].font.size:=fontsize;//设置行字体大小

xlBook.worksheets[1].rows[1].font.bold:=true;  //加粗

xlBook.worksheets[1].rows[1].interior.color:=clskyblue;  //填充色

xlBook.worksheets[1].rows[1].rowheight:=35;//设置行高

xlBook.worksheets[1].rows[1].WrapText:=True;//设置自动换行

xlBook.worksheets[1].rows[1].HorizontalAlignment:=3;//设置一行的水平居中属性

xlBook.worksheets[1].columns[1].ColumnWidth:=15;//设置一列的宽度

xlBook.worksheets[1].usedrange.rows.count //最大行数

xlBook.WorkSheets[1].Cells[1,1] := '姓名';

//合并单元格

xlapp.range[xlBook.workSheets[1].cells[2,1],xlBook.workSheets[1].cells[2,3]].merge;

//冻结窗口 冻结所激活的单元格左上方区域

xlBook.worksheets[1].cells[10,10].activate;

xlapp.activeWindow.FreezePanes:=true;

//边框

xlBook.worksheets[1].range[xlBook.worksheets[1].cells[3,1],xlBook.worksheets[1].cells[5,1]].borders[m].linestyle:=1;//m的含义:1-左 2-右 3-顶 4-底 5-斜( \ ) 6-斜( / )

xlBook.worksheets[1].range[xlBook.worksheets[1].cells[loldRowIdx,1],xlBook.worksheets[1].cells[lrowIdx -1,lDeepth]].borders.linestyle:=1;//range内所有单元格边框显示
xlBook.worksheets[1].range[xlBook.worksheets[1].cells[loldRowIdx,1],xlBook.worksheets[1].cells[lrowIdx -1,lDeepth]].borders[11].linestyle:=-4142; //去除range内部子单元格边框11:横线,12竖线,-4142代表清除 (神奇的东西,网上很难搜到。。)
xlBook.worksheets[1].range[xlBook.worksheets[1].cells[loldRowIdx,1],xlBook.worksheets[1].cells[lrowIdx -1,lDeepth]].borders[12].linestyle:=-4142;

//插入图片操作,前提是图片必须存在电脑中插入后也不可以删除;

picture := xlBook.WorkSheets[1].Pictures.Insert(headFname); //插入图片

picture.left := xlBook.WorkSheets[1].Cells[idx,1].left + 1; //左

picture.top := xlBook.WorkSheets[1].Cells[idx,1].top + 1; //高

picture.width := xlBook.WorkSheets[1].Cells[idx,1].width - 2; //宽度

picture.height := xlBook.WorkSheets[1].Cells[idx,1].height - 2; //高度

picture := UnAssigned;

//判断文件是否已经打开
function isFileInUse(fName : string ) : boolean;
var
HFileRes : Tfilestream;
begin
  Result := false;
  if not FileExists(fName) then
    exit;
  try
    hfileres:=Tfilestream.create(fname,fmShareExclusive);
    result:=false;
  except
    result:=true;
  end;
  try
    hfileres.Free;
  except
  end;
end;

delphi下excel的操作的更多相关文章

  1. Delphi对Excel保护操作

    http://www.docin.com/p-378093577.html在金融系统的应用系统中经常需要与Excel交换数据或利用Excel制作报表,但在某些情况下,我们的业务系统要求生成的临时或最终 ...

  2. 小白学 Python(24):Excel 基础操作(下)

    人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...

  3. Delphi的注册表操作

    转帖:Delphi的注册表操作 2009-12-21 11:12:52 分类: Delphi的注册表操作 32位Delphi程序中可利用TRegistry对象来存取注册表文件中的信息.     一.创 ...

  4. VS2010 MFC对Excel的操作

    这是帮别人做项目遇到的一个问题,的那个是纠结了老长时间,本以为是一件很轻松的事... 首先,这里采用了OLE来对Excel进行操作,网上其实有大把的例子,虽然都可以运行,但是并不能满足项目要求,其实我 ...

  5. DELPHI下的SOCK编程(转)

    DELPHI下的SOCK编程      本文是写给公司新来的程序员的,算是一点培训的教材.本文不会涉及太多的编程细节,只是简单讲解在DELPHI下进行Winsock编程最好了解的知识. 题外话:我认为 ...

  6. DELPHI下API简述(1800个API)

    DELPHI下API简述 http://zero.cnbct.org/show.asp?id=144 auxGetDevCaps API 获取附属设备容量 auxGetNumDevs API 返回附属 ...

  7. java导入导出excel常用操作小结及简单示例

    POI中常用设置EXCEL的操作小结: 操作excel如下 HSSFWorkbook wb = new HSSFWorkbook();  //创建一个webbook,对应一个Excel文件 HSSFS ...

  8. Delphi下的RTTI函数大全

    http://ljz9425.blog.163.com/blog/static/369148572008111635253858/ Delphi下的RTTI(下) 2008-12-16 15:52:5 ...

  9. Delphi中文本文件的操作

    Delphi中文本文件的操作 相关知识内容: 在对文本文件进行任何处理之前,首先要打开此文本文件.声明变量:通过此变量可以来引用一个文本文件. 打开一个文件需要两步:首先是 AssignFile(), ...

随机推荐

  1. [Liferay] Liferay 实现单点登录 - OpenLDAP

    Liferay 的单点登录绝对是个难啃的骨头,更何况网上能搜到的基本都是些滥竽充数的文章,很不负责任. 于是在自己搭通单点登录一条线之后,决定整理下思路并写出来,希望各位能别重蹈覆辙. 本文不介绍概念 ...

  2. 【Android进阶】怎样使用文件来保存程序中的数据

    在程序中.有非常多保存和获取数据的方法,本篇文章,主要介绍使用文件系统对程序中的数据进行保存和读取的操作 我直接写了一个帮助类,进行文件的写入和读取操作 /** * 用于在文件里保存程序数据 * * ...

  3. silverlight计时器

    引用using System.Windows.Threading; DispatcherTimer dispatchertimer = new DispatcherTimer();//创建一个新的计时 ...

  4. C语言-Makefile经典教程(掌握这些足够)

     makefile很重要 什么是makefile? 或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional 的 ...

  5. cygwin开发环境搭建与apt-cyg的应用

    1.Cygwin安装 http://www.cygwin.com/下载安装工具 详细安装过程參照http://jingyan.baidu.com/article/6b97984d83dfe51ca2b ...

  6. Mac 常用命令介绍

    1.查看所有shell cat /etc/shells 2.查看当前使用的shell类型 $ echo $SHELL 3.

  7. Atitit,通过pid获取进程文件路径 java php  c#.net版本大总结

    Atitit,通过pid获取进程文件路径 java php  c#.net版本大总结 1. 通过PID获取进程路径的几种方法2 1.1. GetModuleFileNameEx 想获得进程可执行文件的 ...

  8. TBS 手册 --phpv 翻译

    为何使用它? 示例 下载 手册 支持 论坛 推荐 秀出你的站点 http://phpv.net/TBS_Manual.htm#html_automatic 网站: http://www.tinybut ...

  9. spring boot 打包报错

    [ERROR] Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:1.3.0.RELEASE:repac ...

  10. Could not calculate build plan

    问题:根据你提供的镜像地址,下载相应的jar包失败 原因: 1.你提供的镜像地址不稳定,把settings.xml文件中的mirror改成稳定的镜像地址 2.网络不稳定,重新下载,或者切换网络.