[转]Delphi导出Excel的设置操作
- procedure CreatRepSheet(SheetName:String;PageSize,PageLay:Integer);
- {新建Excel工作簿、进行页面设置}
- begin
- {新建Excel工作簿}
- if ExlApp.WorkBooks.Count < then
- begin
- ExlBook := ExlApp.Workbooks.Add; //ExlBook:=ExlApp.WorkBooks[].WorkSheets[];
- ExlApp.ActiveSheet.Name:=SheetName;
- end; {if}
- {进行页面设置}
- 以上是怎么不用空间而调用EXCEL的, 很方便的!
- //设置页面
- if PageSize= then
- ExlApp.ActiveSheet.PageSetup.PaperSize := xlPaperA3; //纸张大小: A3
- if PageSize= then
- ExlApp.ActiveSheet.PageSetup.PaperSize := xlPaperA4; //纸张大小: A4
- if PageSize= then
- ExlApp.ActiveSheet.PageSetup.PaperSize := xlPaperB5; //纸张大小: B5
- if PageLay= then
- ExlApp.ActiveSheet.PageSetup.Orientation := xlportrait; //页面放置方向:纵向
- if PageLay= then
- ExlApp.ActiveSheet.PageSetup.Orientation := xlLandscape; //页面放置方向:横向
- //设置页宽自动适应
- ExlApp.ActiveSheet.PageSetup.Zoom := False;
- ExlApp.ActiveSheet.PageSetup.FitToPagesWide := ;
- ExlApp.ActiveSheet.PageSetup.FitToPagesTall := False;
- //设置页眉、页脚(即:页标题、页号)
- ExlApp.ActiveSheet.PageSetup.RightFooter := '打印时间: ' + '&D &T';
- ExlApp.ActiveSheet.PageSetup.CenterFooter := '第&''&P&''页,共&''&N&''页';
- //设置页边距:
- ExlApp.ActiveSheet.PageSetup.TopMargin := 1.5/0.035;
- ExlApp.ActiveSheet.PageSetup.BottomMargin := 1.5/0.035;
- ExlApp.ActiveSheet.PageSetup.LeftMargin := /0.035;
- ExlApp.ActiveSheet.PageSetup.RightMargin := /0.035;
- ExlApp.ActiveSheet.PageSetup.HeaderMargin:= 0.5/0.035;
- ExlApp.ActiveSheet.PageSetup.FooterMargin := 0.5/0.035;
- //设置页面对齐方式
- ExlApp.ActiveSheet.PageSetup.CenterHorizontally := True; //页面水平居中
- //ExlApp.ActiveSheet.PageSetup.CenterVertically := True; //页面垂直居中
- //设置整体字体格式
- ExlApp.Cells.Font.Name := '宋体'; //字体
- ExlApp.Cells.Font.Size := ; //字号
- ExlApp.Cells.RowHeight := ; //行高
- ExlApp.Cells.VerticalAlignment := ; //垂直方向对齐方式:居中
- end; {CreatRepSheet}
- procedure SetAddMess(H_Mess1,H_Mess2,H_Mess3,F_Mess1,F_Mess2,F_Mess3:String);
- //用户自定义页眉、页脚(即:页标题、页号)
- begin
- ExlApp.ActiveSheet.PageSetup.LeftHeader:=H_Mess1;
- ExlApp.ActiveSheet.PageSetup.CenterHeader:=H_Mess2;
- ExlApp.ActiveSheet.PageSetup.RightHeader:=H_Mess3;
- end;{SetAddMess}
- procedure SetRepBody(x,ch:Integer;cw:Double;cf:String);
- //设置整体各列数据格式
- begin
- ExlApp.ActiveSheet.Columns[x].ColumnWidth:=cw; //列宽
- ExlApp.ActiveSheet.Columns[x].NumberFormat:=Cf; //单元格数据格式
- ExlApp.ActiveSheet.Columns[x].HorizontalAlignment:=ch; //水平方向对齐方式
- end;{SetRepBody}
- procedure CreatTitle(TitleName:String;y:Integer);
- {设置标题}
- Var
- RepSpace:String;
- begin
- CellMerge(,,,y);
- ExlApp.cells(,):=TitleName;
- RepSpace:='A1'+':'+GetRepRange(,y);
- ExlApp.Range[RepSpace].Select;
- ExlApp.Selection.NumberFormat :='G/通用格式';
- ExlApp.Selection.Font.Size:=;
- ExlApp.Selection.Font.Name:='黑体';
- ExlApp.Selection.Font.Bold:=True;
- ExlApp.Selection.HorizontalAlignment:=; //水平方向对齐方式:居中
- ExlApp.Rows[].RowHeight:=;
- end;{RepHead}
- procedure CreatSubHead(SubTitle: Array of String);
- {设置常规子表头}
- Var
- i,j:Integer;
- begin
- j:=;
- for i:=Low(SubTitle) to High(SubTitle) do
- begin
- Inc(j);
- ExlApp.cells(,j):=SubTitle[i];
- end;
- end;{CreatRepHead}
- procedure SubHeadFormat(y,r:Integer);
- {设置子表头格式}
- Var
- RepSpace:String;
- n:Integer;
- begin
- RepSpace:='A2'+':'+GetRepRange(+r,y);
- ExlApp.Range[RepSpace].Select;
- ExlApp.Selection.NumberFormat :='G/通用格式';
- ExlApp.Selection.HorizontalAlignment:=; //表头水平对齐方式:居中
- ExlApp.Selection.Font.Bold:=True;
- for n:= to r do
- begin
- ExlApp.Rows[+n].RowHeight:=;
- SetRepLine(+n,y);
- end;{for}
- end;{SubHeadFormat}
- procedure DTSubHeadGS(x,y,r:Integer);
- {设置动态子表头格式}
- Var
- RepSpace:String;
- n:Integer;
- begin
- RepSpace:=GetRepRange(x,)+':'+GetRepRange(x+r-,y);
- ExlApp.Range[RepSpace].Select;
- ExlApp.Selection.NumberFormat :='G/通用格式';
- ExlApp.Selection.HorizontalAlignment:=; //表头水平对齐方式:居中
- ExlApp.Selection.Font.Bold:=True;
- for n:= to r- do
- begin
- ExlApp.Rows[x+n].RowHeight:=;
- SetRepLine(x+n,y);
- end;{for}
- end;{DTSubHeadGS}
- procedure WriteData(RepData: String; x,y,flag:Integer); //写入数据
- {写数据}
- begin
- if flag= then
- ExlApp.cells(x,y):=StrToDate(RepData)
- else
- ExlApp.cells(x,y):=RepData;
- end;{WriteDate}
- procedure RepPageBreak(x,y,r:Integer); //X:分页处行数,Y:列数,R:子表头总共的行数
- //分页、复制表头
- Var
- RepSpace:String;
- n:Integer;
- begin
- ExlApp.ActiveSheet.Rows[x].PageBreak := ;
- RepSpace:='A1'+':'+GetRepRange(r+,y);
- ExlApp.ActiveSheet.Range[RepSpace].Copy;
- RepSpace:='A'+IntToStr(x);
- ExlApp.ActiveSheet.Range[RepSpace].PasteSpecial;
- ExlApp.Rows[x].RowHeight:=;
- for n:= to r do
- ExlApp.Rows[x+n].RowHeight:=;
- end;{RepPageBreak}
- procedure RepSaveAs(FileName:String);
- {保存为*.xls文件}
- begin
- try
- ExlBook.saveas(FileName);
- except
- MessageDlg('不能访问文件,请关闭Microsoft Excel后再运行本程序!', mtError, [mbOk], );
- end;
- end;{RepSaveAs}
- procedure RepPrivew(FileName:String);
- {预览}
- begin
- RepCreat;
- ExlApp.Visible :=True;
- try
- ExlApp.workBooks.Open(FileName);
- ExlApp.Workbooks[].WorkSheets[].PrintPreview;
- finally
- ExlApp.Quit;
- ExlApp:=Unassigned;
- //ExlApp:='';
- end;{try}
- end;{RepPrivew}
- procedure RepQuit;
- {退出Excel}
- begin
- ExlBook.Close;
- ExlApp.Quit; //退出Excel Application
- ExlApp:=Unassigned; //释放VARIANT变量
- end;{RepQuit}
- procedure RepDestroy;
- {非正常退出Excel}
- begin
- if Not VarIsEmpty(ExlApp) then
- RepQuit;
- end;{RepDestroy}
- end.
[转]Delphi导出Excel的设置操作的更多相关文章
- Delphi导出Excel的设置操作
procedure CreatRepSheet(SheetName:String;PageSize,PageLay:Integer); {新建Excel工作簿.进行页面设置} begin {新建Exc ...
- NPOI导出EXCEL 打印设置分页及打印标题
在用NPOI导出EXCEL的时候设置分页,在网上有查到用sheet1.SetRowBreak(i)方法,但一直都没有起到作用.经过研究是要设置 sheet1.FitToPage = false; 而 ...
- [转]NPOI导出EXCEL 打印设置分页及打印标题
本文转自:http://www.cnblogs.com/Gyoung/p/4483475.html 在用NPOI导出EXCEL的时候设置分页,在网上有查到用sheet1.SetRowBreak(i)方 ...
- C#+Aspose.Cells 导出Excel及设置样式 (Webform/Winform)
在项目中用到,特此记录下来,Aspose.Cells 不依赖机器装没有装EXCEL都可以导出,很方便.具体可以参考其他 http://www.aspose.com/docs/display/cells ...
- POI操作EXCEL之导出Excel(设置有效性,下拉列表引用)
本人使用的是poi-bin-3.10-FINAL-20140208.zip 版本的poi以下是程序关键代码: //需要引用的类 import java.io.File; import java.io. ...
- C#导出Excel,并且设置Excel单元格格式,合并单元格.
注:要添加COM组件 Microsoft Excel 11.0 Object Library 引用. 具体代码如下: using System; using System.Collections.G ...
- PHP导出Excel,设置表格样式,填充颜色等较为复杂样式
// 注:只是在此做下记录,有兴趣的可以参考,不做实际教程文档 <?php //引入Li类对数据进行操作include_once('./Li.php');//引入Excel类库对对数据进行操作i ...
- 利用PHPExcel导出Excel并设置Excel格式以及数据源
浏览:23969 发布日期:2013/07/24 分类:技术分享 代码有点长,读起来有点累.先来个截图 导出的Excel太宽了,所以将后面的列宽重新调整了再截的图 功能包括: 1.设置单元格格式,包括 ...
- DevExpress导出Excel样式设置
/// <summary> /// 导出到Excel /// </summary> /// <param name="gridControl"> ...
随机推荐
- 用c写99乘法表
int main(int argc,char **argv){ int a; for(a=1;a<=9;a++){ int b; for(b=1;b<=a;b++){ printf(&qu ...
- Inotify: 高效、实时的Linux文件系统事件监控框架
Inotify: 高效.实时的Linux文件系统事件监控框架 概要 - 为什么需要监控文件系统? 在日常工作中,人们往往需要知道在某些文件(夹)上都有那些变化,比如: 通知配置文件的改变 ...
- selenuim ide回放时出现的问题
[error] Unexpected Exception: fileName -> chrome://selenium-ide/content/selenium-core/scripts/htm ...
- Vagrant网络配置
Vagrant中网络配置 一.基本配置 Vagrant offers multiple options for how you are able to connect your guest machi ...
- Directx 3D编程实例:随机绘制的立体图案旋转
最近朋友建议我写一些关于微软云技术的博客留给学校下一届的学生们看,怕下一届的MSTC断档.于是我也觉的有这个必要. 写了几篇博客之后,我觉得也有必要把这一年的学习内容放在博客做个纪念,就这样写了本篇博 ...
- Linux下设置允许myql数据库远程连接
系统环境: Linux ubuntu --generic #-Ubuntu SMP Thu Apr :: UTC x86_64 x86_64 x86_64 GNU/Linux 系统中已经安装好mysq ...
- JavaScript中的[]和{}
最早开始对js中括号的使用有疑问是在交互2值的时候: a = [b,b=a][0]; 详见JavaScript交换两个变量值的七种解决方案 因为 [[]][0] 的意思是:获取 [[]] 的第一个元素 ...
- POJ 3414 Pots ( BFS , 打印路径 )
题意: 给你两个空瓶子,只有三种操作 一.把一个瓶子灌满 二.把一个瓶子清空 三.把一个瓶子里面的水灌到另一个瓶子里面去(倒满之后要是还存在水那就依然在那个瓶子里面,或者被灌的瓶子有可能没满) 思路: ...
- 动态规划 is beginning。。。。。。。。。
感觉动态规划非常模糊,怎么办呢??? 狂刷题吧!! !! ! !!! ! !!! !! ! ! ! .!! ..!.! PKU PPt 动规解题的一般思路 1. 将原问题分解为子问题 ...
- PHP ORM框架与简单代码实现(转)
对象关系映射(Object Relational Mapping,简称ORM)是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述对象和数据库之间映射的元数据 ...