[转]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"> ...
随机推荐
- linux下so动态库一些不为人知的秘密(转)
linux 下有动态库和静态库,动态库以.so为扩展名,静态库以.a为扩展名.二者都使用广泛.本文主要讲动态库方面知识.基本上每一个linux 程序都至少会有一个动态库,查看某个程序使用了那些动态库, ...
- php socket 通信
Socket扩展是基于流行的BSD sockets,实现了和socket通讯功能的底层接口,它可以和客户端一样当做一个socket服务器. 想了解更通用的客户端socket接口,请看 stream_s ...
- java学习面向对象之static内存图解
上一节当中描述了static的用法,以及成员变量和静态变量的区别.但是static除了可以修饰成员变量使之成为静态变量外,他还可以同时修饰函数,使之成为静态函数,我们来看一个例子: class Sta ...
- java学习之查找
在一组数据当中我们取出一个我们想要的数据的过程,谓之查找. 1.简单查找: 需求:在一组数据当中找到你想要的一个数据,并且返回该数据在数组当中的索引. 思路:循环遍历整个数组,然后拿各个元素与所要找出 ...
- 构造函数语义学之Copy Constructor构建操作(2)
二.详述条件 3 和 4 那么好,我又要问大家了,条件1 和 2比较容易理解.因为member object或 base class 含有copy constructor.那么member objec ...
- 学习C++所需看的书和顺序
初学: <C++ 编程思想> <C++ Primer><The C++ Programming Language> 提高: <C++ 的发展与演化> & ...
- 【搜索】【并查集】Codeforces 691D Swaps in Permutation
题目链接: http://codeforces.com/problemset/problem/691/D 题目大意: 给一个1到N的排列,M个操作(1<=N,M<=106),每个操作可以交 ...
- 加密混淆.Net程序
记录在这里,以便学习使用! 一 加密混淆.Net程序 打开Intellilock进处此界面 点击add按钮加入你要操作的程序集, Merge Assemblie 可以合并当前程序集列表中的程序集为一个 ...
- MVC传值方式及优缺点
说在前面文章转自 http://www.cxyclub.cn/n/49493/ 在MVC控件器传递多个Model到视图,使用ViewData,ViewBag,部分视图,TempData,ViewMod ...
- [转载]软件测试之Web测试经典总结
转载自:软件测试之Web测试经典总结 基于Web的系统测试在基于Web的系统开发中,如果缺乏严格的过程,我们在开发.发布.实施和维护Web的过程中,可能就会碰到一些严重的问题,失败的可能性很大.而且, ...