导出Excel1 - 项目分解篇
我们在全部的MIS系统(信息管理系统)中都能见到他。所以我们把这个通用功能提出来。
项目名称:车辆信息管理系统(中石化石炼)
项目负责人:xiaobin
项目时间:2006.12 - 2007.2
Excel功能模块:
单击事件(Event):
procedure EXCELE1Click(Sender: TObject);
- procedure TfrmMain.EXCELE1Click(Sender: TObject);
- var
- colnum,slnum,i:integer;
- headstr:string;
- begin
- if DataSource_carNum.DataSet.RecordCount=0 then Exit;
- //
- DataModule_ado.ADODataSet_Excel.Close;
- DataModule_ado.ADODataSet_Excel.Open;
- //
- TreeView1.Items.Clear;
- Memo2.Lines.Clear ;
- colnum:=DataModule_ado.ADODataSet_Excel.FieldDefList.Count;
- Maxnum :=1;
- //slnum:=0;
- for i:=1 to colnum do
- begin
- slnum:=1;
- headstr:=DataModule_ado.ADODataSet_Excel.FieldDefList[i-1].Name;
- while Pos('|',headstr) > 0 do
- begin
- Delete(headstr, 1, Pos('|', headstr));
- slnum:=slnum+1;
- end;
- if slNum>Maxnum then Maxnum:=slNum;
- end;
- treeADO(DataModule_ado.ADODataSet_Excel,TreeView1);
- try
- myexcel := createoleobject('excel.application');
- myexcel.application.workbooks.add;
- myexcel.caption:=pnlLog.Caption;
- myexcel.application.visible:=true;
- workbook:=myexcel.application.workbooks[1];
- worksheet:=workbook.worksheets.item[1];
- except
- application.MessageBox('没有发现Excel,请安装office!','提示信息',
- MB_OK + MB_ICONINFORMATION);
- exit;
- end;
- WriteheaderADO(DataModule_ado.ADODataSet_Excel,pnlLog.Caption,9,TreeView1);
- WriteExcelData(DataModule_ado.ADODataSet_Excel);
- //页脚设置
- myexcel.activesheet.pagesetup.centerfooter:='第&P页';
- //
- worksheet.saveAs(excelDir+'\'+dateTimeStrFull+'lcbzsx.xls');
- //workbook.close;
- //myexcel.quit;
- //add logmemo
- frame1.addMemoLog(EXCELE1.Caption);
- end;
代码凝视:
第6行:假设DataSource(Delphi控件)当前无数据,则退出此事件。
第8行:DataModule_ado为DataModule(Delphi控件 - 数据容器)
第13行:依据ADODataSet_Excel(Delphi控件 - ADODataSet)字段列表。得到Excel列数。
第20-24行:多表头层数计算。
大部分我们用:父表头|子表头|孙表头,来表示一个多表头数据。
第27行:运行treeADO子过程,把表头的层次关系用TreeView(Delphi控件)表示出来。
第28-39行:初始化Excel对象。
myExcel:variant; //电子表格对象
workbook:olevariant; //电子表格部分
worksheet:olevariant; //电子表格工作簿
第40行:运行WriteheaderADO子过程。写Excel表头。
第41行:运行WriteExcelData子过程, 写Excel数据。
导出Excel1 - 项目分解篇的更多相关文章
- [转]Android开源项目第二篇——工具库篇
本文为那些不错的Android开源项目第二篇--开发工具库篇,主要介绍常用的开发库,包括依赖注入框架.图片缓存.网络相关.数据库ORM建模.Android公共库.Android 高版本向低版本兼容.多 ...
- Android开源项目第二篇——工具库篇
本文为那些不错的Android开源项目第二篇——开发工具库篇,**主要介绍常用的开发库,包括依赖注入框架.图片缓存.网络相关.数据库ORM建模.Android公共库.Android 高版本向低版本兼容 ...
- Android开源项目第一篇——个性化控件(View)篇
本文为那些不错的Android开源项目第一篇——个性化控件(View)篇,主要介绍Android上那些不错个性化的View,包括ListView.ActionBar.Menu.ViewPager.Ga ...
- Android开发UI之开源项目第一篇——个性化控件(View)篇
原文:http://blog.csdn.net/java886o/article/details/24355907 本文为那些不错的Android开源项目第一篇——个性化控件(View)篇,主要介绍A ...
- 洗礼灵魂,修炼python(82)--全栈项目实战篇(10)—— 信用卡+商城项目(模拟京东淘宝)
本次项目相当于对python基础做总结,常用语法,数组类型,函数,文本操作等等 本项目在博客园里其他开发者也做过,我是稍作修改来的,大体没变的 项目需求: 信用卡+商城: A.信用卡(类似白条/花呗) ...
- C# Xamarin移动开发项目实战篇
一.课程介绍 在前面阿笨的<C# Xamarin移动开发基础进修篇>课程中,大家已经熟悉和了解了Xamarin移动App开发的基础知识和原理.本次分享课<C# Xamarin移动开发 ...
- 菜鸟教程之工具使用(七)——从GIt上导出Maven项目
今天继续我们的工具教程,公司用Git作为版本控制工具,所以最近一直在跟Git打交道.也是一边学习一边使用,于是想做一些入门教程,一来自己总结一下,二来还能帮助一些刚刚接触Git的朋友.一举两得,何乐而 ...
- unity 代码有调整,重新导出 iOS 最烦的就是 覆盖导出后项目不能打开
unity 代码有调整,重新导出 iOS 最烦的就是 覆盖导出后项目不能打开,原因是 editor 里面的脚本,破坏了 Unity-iPhone.xcodeproj 里面的结构,具体是什么原因,也不 ...
- 导出/打印项目数据报表需要设置IE浏览器
导出/打印项目数据报表需要设置IE浏览器如下: 1.将本地服务器站点设置为可信站点, 2.通过点击网页上的工具→Internet选项→安全→自定义级别→把关于activeX控件和插件的选项都设置成启用 ...
随机推荐
- Dev控件treeList
之前做过一段时间,当时copy 的别人的代码,这就就把节点给添加了,上次帮同事做也发现了这个问题,当时没有记下来,今天有做,磨了半天,记下来吧. Dev控件treeList 要添加节点第一步是右键添加 ...
- [转载] 深入剖析 redis 主从复制
转载自http://www.cnblogs.com/daoluanxiaozi/p/3724299.html 主从概述 redis 支持 master-slave(主从)模式,redis server ...
- Openstack的打包方法
使用setup.cfg和setup.py进行管理 1.setup.py文件内容 # THIS FILE IS MANAGED BY THE GLOBAL REQUIREMENTS REPO - DO ...
- pt-online-schema-change和默认值关系
在使用pt-online-schema-change会遇到如下的错误导致表修改失败: Copying rows caused a MySQL error 1364,Message: Field 'XX ...
- Android ANR异常解决方案
1,ANR异常的解释: ANR(android not response)即应用程序无响应,在用户操作在5秒内没有响应的话就会出现ANR异常: 2,那为什么会出现ANR异常呢? Android系统中处 ...
- javascript函数式编程(一)
一.引言 javascript函数式编程在最近两年来频繁的出现在大众的视野,越来越多的框架(react,angular,vue等)标榜自己使用了函数式编程的特性,好像一旦跟函数式编程沾边,就很高大上一 ...
- keras 修仙笔记一
对于牛逼的程序员,人家都喜欢叫他大神:因为大神很牛逼,人家需要一个小时完成的技术问题,他就20分钟就搞定.Keras框架是一个高度集成的框架,学好它,就犹如掌握一个法宝,可以呼风唤雨.所以学keras ...
- 一篇不错的Gibbs Sampling解释文章,通俗易懂
http://cos.name/2013/01/lda-math-mcmc-and-gibbs-sampling/ 直接原文的链接了.原文写的不错,是中文博客中说的比较明白的了. 但为了保留文章,随 ...
- JavaScript学习笔记(十二)——箭头函数(Arrow Function)
在学习廖雪峰前辈的JavaScript教程中,遇到了一些需要注意的点,因此作为学习笔记列出来,提醒自己注意! 如果大家有需要,欢迎访问前辈的博客https://www.liaoxuefeng.com/ ...
- Linux系统bashshell之别名
1.别名的查看: 命令查看:alias 配置文件查看:cat ~/.bashrc 2:别名设置: alias cdnet="cd /etc/sysconfig/network-scri ...